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近 几 年 来 ,， PHP 成 为 流行 的 Web 开发 语言 之 一 。 它 在 国内 的 发 展 非常 迅速 ， 儿 乎 所 有 
的 虚拟 主机 和 大 部 分 服务 器 都 支持 PHP。PHP 作为 功能 强大 的 Web 编程 语言 ， 以 其 简单 易 
学 、 安 全 性 高 和 跨 平台 等 诸多 特性 越 来 越 受 到 广大 Web 开发 者 的 关注 和 喜爱 。 

现在 ， 越 来 越 多 的 人 开始 关注 、 学 习 和 使 用 PHP， 但 是 与 其 他 Web 开发 语言 相 比 ， 专 
门 介绍 PHP 的 书籍 却 很 少 , 很 多 PHP 初学 者 都 苦于 找 不 到 一 本 通俗 易 懂 、 简 单 实 用 的 PHP 
入 门 教 材 。 笔 者 最 近 几 年 都 在 使 用 PHP， 积 累 了 丰富 的 经 验 ， 并 在 此 基础 上 组 织 多 名 有 丰 
富 开发 经 验 的 人 员 共 同 编写 了 本 书 ， 希 望 引导 初学 者 快速 入 门 ， 帮 助 那些 喜爱 PHP 的 朋友 
走 上 学 习 PHP 的 捷径 。 

本 书 响应 教学 需求 ， 以 项 目 任务 式 方法 编写 ， 对 每 个 知识 点 都 进行 了 针对 性 的 讲解 。 
在 内 容 选 取 上 以 实用 性 为 原则 ， 做 到 不 求 面 广 ， 但 求实 用 。 本 书 突出 案例 教学 ， 避 免 空 洞 
的 描述 ， 每 个 项 目 任务 的 内 容 都 通过 对 案例 的 深入 分 析 和 上 机 操作 加 深 读 者 对 所 学 知识 的 
理解 ， 提 高 学 习 效 果 和 动手 能 力 。 本 书 最 后 的 两 个 实用 案例 将 全 书 内 容 与 典型 的 实际 应 用 
联系 起 来 , 也 将 全 书 的 案例 体系 串联 起 来 , 使 读者 能 够 学 到 最 贴近 应 用 前 沿 的 知识 和 技能 。 

本 书 共 分 为 8 个 项 目 ， 循序渐进 地 讲解 了 在 初学 PHP 编程 时 所 要 掌握 的 基础 内 容 ， 其 
中 包括 搭建 PHP 开发 环境 、PHP 编程 基础 的 学 习 、PHP 中 函数 的 学 习 、 初 识 MySQL 数据 
库 、PHP+MySQL 编程 、PHP 面向 对 象 编程 等 内 容 ， 并 在 最 后 讲解 了 两 个 经 典 案例 ， 以 帮 
助 读者 理解 前 面 的 基础 内 容 并 进行 实践 。 

本 书 由 广东 建设 职业 技术 学 院 王 咸 锋 、 黄 妙 燕 主 编 ， 广 东 创 新 科技 职业 学 院 曾 德 生 、 
郑州 轻工业 学 院 张 娜 、 辽 宁 信 息 职业 技术 学 院 张 晓 琦 为 副 主编 。 其 中 项 目 一 、 项 目 二 由 王 
咸 锋 编 写 ， 项 目 三 由 黄 妙 燕 编 号， 项目 四 、 项 目 五 由 曾 德 生 编写 ， 项 目 六 、 项 目 七 由 张 娜 
编写 ， 项 目 八 由 张 晓 琦 编写 。 

本 书 可 作为 高 等 院 校 计算 机 类 专业 的 专业 课 教材 ,也 可 以 作为 学 习 Web 开发 技术 人 员 
的 入 门 自学 教材 ， 还 是 初 、 中 级 PHP 开发 者 首选 的 参考 书 。 

本 书 在 编写 时 力求 完美 、 准 确 ， 但 是 由 于 作者 水 平 有 限 ， 编 写 时 间 仓 促 ， 书 中 不 足 之 
处 在 所 难免 ， 敬 请 各 位 同行 和 广大 读者 批评 指正 。 
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初步 认识 PHP 及 相关 配置 


知识 点 、 技 能 点 


> 静 态 网 页 与 动态 网 页 
> PHP 的 简介 与 发 展 
> PHP 代码 

> PHP 开发 环境 要 求 
> 


PHP 开发 环境 搭建 


> 掌握 静态 网 页 与 动态 网 页 的 区 别 
> 了 解 PHP 代码 的 发 展 

> 掌握 PHP 代码 编程 的 基本 结构 
> 掌握 PHP 编程 的 开发 环境 的 搭建 


教学 基础 要 求 


> 掌握 PHP 代码 编程 的 基本 结构 
> 掌握 PHP 编程 的 开发 环境 的 搭建 


任务 1] 初 加 PHP 


任务 描述 


加 “了解 静态 网 页 与 动态 网 页 

回 了 解 PHP 的 发 展 简 史 

回 ”初步 认识 PHP 代码 及 PHP 编程 

要 想 学 习 PHP， 首 先 要 了 解 什么 是 PHP、 如 何 使 用 PHP。 任 务 1 将 回答 这 些 问 题 ， 使 
读者 对 PHP 及 其 发 展 有 一 个 大 致 的 了 解 ， 同 时 将 初步 学 习 如 何 把 PHP 代码 加 入 到 普通 的 
Web 页 中 ， 如 何 为 PHP 代码 加 入 注释 以 及 PHP 的 文件 引用 的 特性 。 在 任务 1 的 学 习 中 需 


要 注意 以 下 几 点 : 一 是 谨慎 使 用 代码 <?php ?> 和 <script language="php"></script>; 二 是 不 
要 使 用 多 重 注释 ， 三 是 使 用 include 和 require 方法 引用 文件 时 文件 必须 存在 。 
知识 汇总 


1.1.1 静态 网 页 与 动态 网 页 


目前 ， 网 页 有 静态 和 动态 两 种 形式 。 在 讲解 这 两 种 网 页 之 前 ， 先 了 解 一 下 网 络 构 成 中 
的 客户 机 (Browser) 与 服务 器 (Server)。 服 务 器 是 安装 有 服务 软件 ， 可 以 向 客户 机 提供 诸 
如 网 页 浏览 、 数 据 库 查 询 等 服务 的 设备 。 而 客户 机 与 之 相反 ， 它 通过 客户 端 软件 ， 如 网 页 
浏览 器 从 服务 器 上 获得 网 页 浏览 、 软 件 下 载 等 服务 。 简 单 地 讲 ， 服 务 器 就 是 服务 提供 者 ， 
而 客户 机 则 是 服务 获得 者 。 

1， 传统 的 静态 网 页 HTML 

在 WWW 发 展 的 早期 阶段 ， 由 于 受 技术 条 件 的 制约 ， 服 务 器 提供 给 用 户 的 网 页 基本 都 
是 静态 的 HTML 网 页 。 这 种 网 页 通常 只 包含 HTML 标识 ， 没 有 脚本 代码 ， 在 视觉 上 也 可 
能 出 现 “ 动 ”的 效果 ， 如 通过 GIF 动画 、Flash、JavaScript 特效 等 内 容 来 丰富 网 页 ， 但 是 
用 户 每 次 浏览 ， 该 网 页 的 内 容 都 是 一 成 不 变 的 。 
静态 网 页 服务 的 实现 流程 如 下 : 客户 端 通过 浏览 器 向 服务 器 发 出 请 求 ， 服 务 器 根据 请 
求 从 服务 器 端的 网 页 中 选 出 合适 的 网 页 传 回 给 客户 端 浏 览 器 。 该 过 程 中 所 发 送 的 页 面 都 是 
事先 编辑 好 的 ， 并 不 能 自动 生成 。 静 态 网 页 的 实现 模式 如 图 1.1 所 示 。 


发 送 请 求 人 3 
客 二 一 服 
大 传 回 页 面 务 
机 器 


图 1.1 静态 网 页 的 实现 模式 
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静态 网 页 有 以 下 特点 : 

加 ”静态 网 页 不 能 自动 更 新 。 由 于 不 能 自动 更 新 ， 所 以 如 果 要 对 静态 网 页 进行 更 新 ， 
就 要 重新 编写 HTML 页 面 然后 上 传 。 因 此 静态 网 页 制作 和 维护 的 工作 量 相当 大 。 

回 ”静态 网 页 的 内 容 不 随 浏览 用 户 、 浏 览 时 间 等 条 件 的 变化 而 变化 。 无 论 何 人 、 何 时 、 
何 地 浏览 网 页 ， 其 内 容 都 是 一 成 不 变 的 (不 包括 使 用 JavaScript 实现 一 些 简单 
特效 )。 

回 ”静态 网 页 一 经 发 布 ， 无 论 浏览 者 浏览 与 否 ， 它 都 是 实 实 在 在 的 一 个 文件 ， 都 对 应 
一 个 URL“《〈 即 统一 资源 定位 符 ， 指 Intemet 文件 在 网 上 的 地 址 )。 

回 用 静态 网 页 实现 人 机 交互 有 相当 大 的 局 限 性 。 由 于 不 能 动态 生成 页 面 ， 所 以 用 静 
态 网 页 来 实现 人 机 交互 是 很 困难 的 ， 它 在 功能 上 有 很 大 的 限制 。 

2. 动态 网 页 与 静态 网 页 的 区 别 


随 着 网 络 技术 的 不 断 发 展 ， 各 种 动态 网 页 技术 纷纷 显示 出 它们 的 不 凡 魅 力 。 先 是 早期 
出 现 的 CGI， 又 有 现在 流行 的 ASP、PHP、JSP、ASPNET、ColdFushion 等 。 虽 然 这 些 动 
态 语言 分 属于 不 同 公司 开发 〈 其 中 ASP 与 ASPNET 同属 微软 公司 )， 也 有 着 不 同 的 运行 环 
境 和 使 用 方法 ， 但 它们 的 目标 是 一 致 的 ， 就 是 实现 网 页 浏览 者 与 网 页 之 间 的 互动 。 

与 静态 网 页 的 实现 方法 不 同 ， 动 态 网 页 服务 的 实现 过 程 如 下 : 客户 端 向 服务 器 提出 申 
请 ， 服 务 器 根据 用 户 请 求 ， 先 把 动态 网 页 内 部 的 代码 在 服务 器 上 进行 相应 的 处 理 ， 再 把 生 
成 的 结果 传 回 给 客户 端 。 其 模式 如 图 1.2 所 示 。 


,| 


传 回 页 面 
图 1.2 动态 网 页 的 实现 模式 


see 


赔 序 葛 凑 过 


通过 以 上 分 析 ， 与 静态 网 页 相 比 ， 动 态 网 页 有 以 下 特点 : 


回 


\y/ 


动态 网 页 在 服务 器 端 运行 。 客 户 机 上 看 到 的 只 是 网 页 文件 的 返回 结果 ， 不 能 看 到 
源 文件 。 而 静态 网 页 则 只 能 通过 服务 器 把 网 页 文件 原封 不 动 地 传 给 客户 机 ， 本 身 
不 进行 任何 处 理 。 

不 同 的 用 户 、 不 同 的 时 间或 不 同 的 地 点 浏览 同一 个 动态 网 页 ， 根 据 代码 处 理 结果 
不 同 ， 会 返回 不 同 的 内 容 。 

动态 网 页 只 有 用 户 浏览 时 才 会 返回 一 个 完整 的 网 页 ， 而 其 本 身 并 不 是 一 个 独立 存 
在 于 服务 器 的 网 页 文件 。 

与 静态 网 页 相 比 ， 动 态 网 页 更 容易 实现 人 机 交互 。 它 与 数据 库 相 联系 ， 能 实现 更 
为 强大 的 功能 。 

由 动态 网 页 构建 的 网 站 维护 起 来 比 静 态 网 页 更 容易 ， 只 需要 更 新 调用 的 数据 (如 
数据 库 内 容 ) 即 可 。 


1.1.2 PHP 简介 及 其 发 展 


1.1.1 节 介 绍 了 静态 网 页 与 动态 网 页 , 而 PHP 是 动态 网 页 技术 中 的 一 种 , 那么 到 底 什么 
是 PHP? 它 的 发 展 历史 又 是 怎么 样 的 ? 与 其 他 动态 网 页 技术 相 比 ，PHP 都 有 些 什 么 特点 ? 
本 节 将 解答 这 些 问题 。 

1. 什么 是 PHP 

早期 有 人 将 PHP 解释 为 Personal Home Page， 即 个 人 主页 。 也 有 人 将 PHP 称 做 PHP: 
Hypertext Preprocessor。 那 么 到 底 什么 是 PHP 呢 ? 通俗 地 说 ，PHP 是 一 种 服务 器 端 、 跨 平 
台 、HTML 尾 入 式 的 脚本 语言 。 服 务 器 端 执行 的 特性 表明 它 是 动态 网 页 的 一 种 。 跨 平台 ， 
则 是 指 PHP 不 仅 可 以 运行 在 Linux 系统 上 , 同时 也 可 以 运行 在 UNIX 或 者 Windows 系统 上 。 
另外 ， 它 还 可 以 很 简单 地 嵌入 到 普通 的 HTML 页 中 ， 用 户 所 要 做 的 只 是 在 普通 HTML 页 
中 加 入 PHP 代码 即 可 。 

2. PHP 的 发 展 历史 


1995 年 早期 ， 以 Personal Home Page Tools (PHP Tools) 开始 对 外 发 表 PHP 第 一 个 版 
本 ，Rasmus Lerdorf 写 了 一 些 介绍 此 程序 的 文档 ， 并 且 发 布 了 PHP 1.0。 在 早期 的 版 本 中 ， 
提供 了 访客 留言 本 、 访 客 计数 器 等 简单 的 功能 。 以 后 越 来 越 多 的 网 站 使 用 了 PHP， 并 且 强 
烈 要 求 增加 一 些 特性 , 如 循环 语句 和 数组 变量 等 。 在 新 的 成 员 加 入 开发 行列 之 后 ,Lerdorf 在 
1995 年 6 月 8 日 将 PHP/FI 公开 发 布 ， 希 望 可 以 透 过 社 群 来 加 速 程序 开发 与 寻找 错误 。 该 
版 本 被 命名 为 PHP 2， 已 经 有 今日 PHP 的 一 些 雏形 ， 如 类 似 Perl 的 变量 命名 方式 、 表 单 
处 理 功 能 以 及 嵌入 到 HTML 中 执行 的 能 力 。 程 序 语法 上 也 类 似 Perl， 有 较 多 的 限制 ， 不 过 
更 简单 、 更 有 弹性 。PHP/FI 加 入 了 对 MySQL 的 支持 ， 从 此 建立 了 PHP 在 动态 网 页 开发 上 
的 地 位 。 到 了 1996 年 底 ， 有 15000 个 网 站 使 用 PHP/FI。1997 年 ， 任 职 于 Technion IIT 的 
两 个 以 色 列 程序 设计 师 Zeev Suraski 和 Andi Gutmans 重 写 了 PHP 的 剖析 器 ,成 为 PHP 3 
的 基础 。 而 PHP 也 在 这 时 改称 为 PHP: Hypertext Preprocessor。 经 过 几 个 月 测试 ， 开 发 团 
队 在 1997 年 11 月 发 布 了 PHP/FI 2。 随 后 便 开 始 PHP 3 的 开放 测试 ， 最 后 在 1998 年 6 月 
正式 发 布 PHP 3。Zeev Suraski 和 Andi Gutmans 在 PHP 3 发 布 后 开始 改写 PHP 的 核心 , 并 
在 1999 年 发 布 名 为 Zend Engine 的 剖析 器 ， 他 们 也 在 以 色 列 的 Ramat Gan 成 立 了 Zend 
Technologies 来 管理 PHP 的 开发 。2000 年 5 月 22 日 ， 以 Zend Engine 1.0 为 基础 的 PHP 4 
正式 发 布 ，2004 年 7 月 13 日 则 发 布 了 PHP 5，PHP 5 使 用 了 第 二 代 的 Zend Engine。PHP 
包含 了 许多 新 特色 ， 如 强化 的 面向 对 象 功能 、 引 入 PDO (PHP Data Objects， 一 个 存 取 数 据 
库 的 延伸 函数 库 ) 以 及 许多 效能 上 的 增强 。 目 前 PHP 4 已 经 不 再 继续 更 新 ， 以 鼓励 用 户 转 
移 到 PHP 5。2008 年 , PHP 5 成 为 PHP 唯一 的 在 开发 的 PHP 版 本 , PHP 5.3 加 入 了 Late static 
binding 和 一 些 其 他 的 功能 强化 。PHP 6 的 开发 也 正在 进行 中 ， 主 要 的 改进 有 移 除 
register_globals、magic quotes 和 Safe mode 的 功能 。 
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3. PHP 与 其 他 CGI 程序 的 比较 


同样 作为 服务 器 端的 编程 语言 ，PHP 与 其 他 CGI 程序 ， 如 ASP、JSP 等 相 比 较 有 其 自 
身 的 特点 ， 主 要 表现 在 以 下 几 个 方面 : 
回 ”Web 服务 器 支持 方面 。PHP 能 够 被 Apache、IIS 等 多 种 服务 器 支持 ， 而 ASP 只 能 
被 Windows 系统 下 的 IS、PWS 所 支持 。 
回 ”运行 平台 的 支持 。PHP 能 够 很 好 地 运行 于 Linux、UNIX、Windows、FreeBSD 等 
多 种 操作 系统 上 , 而 ASP 只 能 运行 于 Windows 系统 上 。 虽然 JSP 也 能 够 得 到 多 种 
系统 的 支持 ， 但 必须 有 Java 虚拟 机 作为 前 提 条 件 。 
回 ”脚本 语言 的 不 同 。PHP 本 身 就 是 一 种 编程 语言 ， 它 是 吸收 了 C、Java 等 语言 的 综 
合 优势 而 创建 开发 的 一 种 新 语言 。ASP 严格 来 说 并 不 是 一 种 单纯 的 编程 语言 ， 而 
是 一 种 网 络 编程 支持 环境 ， 它 支持 VBScript、JavaScript、Perl 等 多 种 语言 ， 但 一 
般 默 认 使 用 VB 作为 主要 编程 语言 。 而 JSP 使 用 Java 语言 或 JavaScript 作为 其 脚 
本 语言 。 

回 ”数据 库 支 持 不 同 。PHP 通常 与 MySQL 数据 库 结 合 使 用 ， 同 时 它 还 支持 Oracle、 
Sybase、ODBC 等 多 种 数据 库 。ASP 则 通常 与 同属 微软 公司 的 Access、MSSQL 
等 数据 库 配 合 使 用 。JSP 则 使 用 JDBC 来 实现 与 数据 库 的 连接 。 

回 面向 对 象 的 支持 不 同 。ASP 基本 上 是 由 组 件 所 构成 的 , 而 组 件 是 对 象 的 使 用 模式 ， 
因此 ASP 中 对 象 的 使 用 频率 非常 高 ， 可 以 说 处 处 都 是 对 象 。JSP 是 建立 在 可 重用 
的 、 跨 平台 的 组 件 之 上 的 ， 所 以 其 面向 对 象 特性 也 非常 明显 。 在 PHP 5 出现 以 前 ， 
PHP 系列 基本 是 属于 面向 过 程 的 ，PHP 5 的 出 现 改 变 了 这 种 状况 ， 真 正 实现 了 面 
向 对 象 。 


1.1.3 初 识 PHP 代码 


学 习 一 门 新 的 编程 语言 ， 都 需要 从 最 基本 的 程序 开始 ， 约 定 俗 成 的 、 最 基本 的 程序 就 
是 “HELLO WORLD!”。 本 节 就 来 介绍 如 何在 PHP 编程 环境 中 实现 这 一 个 最 基本 的 程序 (在 
学 习 本 节 之 前 请 先 保证 已 经 构建 了 PHP 运行 环境 ,如 果 没 有 请 参看 本 项 目 任 务 2 中 的 相关 
内 容 )。 

1. 在 页 面 中 加 入 PHP 代码 

PHP 是 一 种 可 嵌入 式 的 语言 。 也 就 是 说 ， 它 可 以 很 方便 地 加 入 到 一 般 常 见 的 HIML 页 
面 中 。 用 户 请 求 PHP 文件 时 ， 相 关 的 PHP 代码 先 在 服务 器 端 解释 执行 ， 生 成 新 的 HIML 
信息 ， 再 连同 原 有 的 HTML 代码 一 起 发 送 给 用 户 。 下 面 通过 一 个 实例 来 讲解 怎样 向 普通 的 
HTML 页 中 加 入 PHP 代码 。 

【 例 1.1】 

<html> 

<head> 


<title>hello world</title> 
</head> 
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<body> 

<!-- 以 上 为 普通 的 HTML 代码 ， 以 下 为 PHP 代码 --> 
<2php 
echo"HELLO WORLD!"; 


<!-- 以 上 为 PHP 代码 --> 


把 以 上 代码 保存 为 一 个 PHP 文件 1.1.php。 在 PHP 运行 环境 下 执行 以 上 代码 ， 结 果 如 
图 1.3 所 示 。 

单 从 执行 结果 来 看 ， 例 1.1 中 的 代码 确实 没有 比 单纯 的 HTML 代码 多 执行 任何 东西 。 
而 事实 并 非 如 此 , 页 面 中 显示 的 “HELLO WORLD!” 是 经 过 服务 器 的 解释 才 转 到 客户 端的 。 
其 执行 机 理 如 图 1.4 所 示 。 


发 送 请 求 站 C_ 7 
一 、 客 服 
GE ) 。 le localhost/ 1 ||#7 | x 应 和 
窗 收 大 天。 帮 hello world 机 处 
一 一 一 一 下 
HELLO WORLDI 传 回 页 面 
图 1.3 ”代码 的 执行 结果 图 1.4 PHP 执行 机 理 


经 过 例 1.1 可 以 发 现 ， 把 PHP 代码 加 入 普通 HTML 页 中 ， 只 需要 在 HTML 页 中 加 入 
PHP 代码 的 标记 “<?php”、“?> ”符号 ， 这 两 个 符号 中 间 即 为 pHP 代码 。 这 些 代码 会 先 在 
服务 器 上 解释 ,然后 把 结果 连同 普通 HTML 一 起 返回 给 客户 浏览 器 。 例 1.1 中 的 PHP 代码 
即 为 通过 PHP 中 的 ECHO 语句 ， 打 印 出 一 段 字 符 串 HELLO WORLD!。 

当然 ,“<?php...?>” 标 记 只 是 把 PHP 代码 加 入 到 普通 HTML 页 方法 中 的 一 种 。 除 此 
之 外 , 还 可 以 使 用 <script language="php"></scrip 人 标记 来 把 PHP 代码 加 入 到 HTML 页 面 中 。 


注意 
初学 者 要 切记 ， 无 论 使 用 哪 种 编程 语言 ， 在 编程 时 一 定 要 使 用 英文 输入 法 。 


2. 在 PHP 页 中 加 入 注释 

每 种 语言 都 有 自己 的 注释 方法 ，PHP 也 不 例外 。 注 释 的 内 容 并 不 被 执行 ， 它 可 以 是 任 
何 内 容 。 通 常 ， 注 释 的 目的 是 为 了 向 别人 说 明 自 己 的 程序 ， 所 以 应 该 是 对 程序 、 语 名 的 解 
释 。 一 个 好 的 程序 不 仅 要 有 友好 的 、 完 善 的 代码 ， 同 时 也 要 有 清晰 的 、 易 于 理解 的 注释 。 
在 程序 中 加 入 注释 是 对 自己 工作 的 总 结 ， 也 是 对 别人 的 一 种 尊重 。 

下 面 用 例 1.1 来 说 明 怎 样 在 PHP 代码 中 加 入 注释 。 

【 例 1.2】 


<html> 
we 


@-…— _ -高 等 职业 教育 “十 二 五 ”规划 教材 一 中 


ee 项 目 1 初步 认识 PHP 及 相关 配置 图 一 


<head> 
<title>hello world</title> 
</head> 
<body> 


<2php 

echo"HELLO WORLD!"; /用 echo 打印 字符 串 
> 

<!-- 以 上 为 PHP 代码 --> 

</body> 

</html> 


为 PHP 代码 加 入 注释 通常 有 两 种 方法 : 一 种 是 单行 注释 ， 使 用 “//” 标 记 ， 如 例 1.2 
第 7 行 所 示 ; 另 一 种 是 多 行 注释 ， 使 用 “/**/” 标 记 ， 主 要 用 于 注释 文字 比较 多 的 情况 。 


Fa 
mE 
在 使 用 多 行 注释 标识 时 ， 一 定 不 要 使 用 多 重 注释 。 例 如 下 面 注释 的 使 用 ， 必 然 会 引起 
错误 。 


又 有 注释 出 现 了 ， 这 是 错误 的 
yy 
村 
?> 


在 PHP 中 ， 多 行 注释 并 不 支持 柑 套 。 

3. 文件 的 引用 

PHP 支持 文件 的 引用 ， 这 意味 着 用 户 可 以 把 一 些 全 局 变量 、 专 用 函数 放 到 专门 的 文件 
中 ， 需 要 时 来 引用 这 个 文件 ， 就 可 以 使 用 其 中 的 变量 和 函数 ， 就 像 在 一 个 PHP 文件 中 一 样 
方便 。PHP 有 两 种 引用 文件 的 方法 : require 和 include。 下 面 通过 实例 来 说 明 这 两 种 方法 。 

【 例 1.3】 

<?php 


S$string="HELLO WORLD! "; // 定 义 变量 
?> 


这 段 代码 只 是 定义 了 一 个 字符 串 变 量 ， 把 上 面 的 代码 保存 为 1.2.php。 


<html> 
<head> 
<title> 使 用 include 引用 文件 </title> 
</head> 
<body> 
\Y/ <?php 


加 一 高等 职 业 教育 “十 二 五 " 规划 教材 @ 


include("1.2.php"): /使 用 include 引用 文件 
echos$string; 

?> 

</body> 

</html> 


把 上 面 的 代码 保存 为 1.3.php， 与 string.php 放 在 同一 个 目录 下 。 在 PHP 环境 里 运行 
testphp， 执 行 结 果 与 图 1.3 是 一 样 的 。 
同 理 , 还 可 以 用 require" 文 件 名 ": 来 引用 文件 , 使 用 效果 与 include(" 文 件 名 "); 是 一 样 的 。 


明确 动态 网 页 与 静态 网 页 的 区 别 ， 正 确 识别 网 页 是 动态 网 页 还 是 静态 网 页 ， 正 确认 识 
PHP 代码 的 书写 。 


练习 


1. 简 述 静态 网 页 与 动态 网 页 的 区 别 。 
2. 简 述 PHP 区 别 于 其 他 CGI 程序 的 地 方 。 


任务 2 PHP 的 开发 环境 及 实 落 


任务 描述 


正确 安装 、 配 置 PHP 开发 工具 。 

PHP 是 一 种 服务 器 端 编程 语言 ， 所 以 要 想 运行 PHP 代码 ， 必 须要 有 相应 的 服务 器 环境 
及 解释 器 。PHP 能 够 在 多 种 服务 器 环境 上 运行 ， 但 是 PHP 的 “黄金 搭配 ”还 是 
PHP+Apache+Linux。 作 为 通用 操作 系统 . Linux 远 没 有 Windows 流行 ， 所 以 本 书 的 环境 采 
用 PHP+Apache+Windows 这 样 的 形式 。 本 任务 将 介绍 怎样 在 Windows 操作 系统 下 安装 、 配 


置 PHP 的 运行 环境 。 
知识 汇总 


1.2.1 PHP 开发 环境 简介 


PHP 是 生成 动态 网 页 的 工具 之 一 ，PHP 的 开发 需要 相应 的 开发 环境 及 解释 器 ， 下 面 就 
简单 介绍 一 下 PHP 开发 过 程 中 需要 用 到 的 工具 及 组 件 。 
调试 PHP 程序 需要 安装 以 下 组 件 : 
回 ”Apache: 运行 Web 页 面 的 服务 器 程序 。Apache http server 是 世界 使 用 排名 第 一 的 
Web 服务 器 软件 ， 可 以 运行 在 几乎 所 有 广泛 使 用 的 计算 机 平台 上 。Apache 源 于 
NCSAhttpd 服务 器 ， 经 过 多 次 修改 ， 成 为 世界 上 最 流行 的 Web 服务 器 软件 之 一 。 
回 PHP:， PHP 程序 的 解释 器 。PHP 页 面 会 先 通过 该 解释 器 解释 ， 再 发 送 给 用 户 。 
回 “MySQL: MySQL 数据 库 程序 。 调 试 数 据 库 程序 的 必 备 程序 。 Caf 


上 一 四 .高 等 职业 教育 “十 二 五 ”规划 教材 一 S - 
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加 ” phpMyAdmin: 用 PHP 编写 的 管理 MySQL 数据 库 的 程序 。 使 用 该 程序 可 以 有 效 
管理 MySQL 数据 库 。 
回 EditPlus: PHP 文件 的 编辑 器 。 可 以 编辑 任何 二 


Windows 平台 下 Wamp 的 下 载 安装 


进 制 文件 。 
12:2 


1. Wamp 的 下 载 安装 

WampServer 2.1a 是 PHP+Apache+MYySQL 在 Windows 下 的 集成 环境 , 拥有 简单 的 图 形 
和 菜单 安装 。 该 版 本 集成 了 PHP 5.3.3、MySQL 5.5.8、Apache 2.2.17 和 phpMyAdmin 3.2.0.1， 
满足 了 大 部 分 PHP 开发 人 员 的 需求 。 

在 这 里 说 明 一 下 为 什么 选择 Wamp 而 不 是 自己 安装 配置 各 个 环境 工具 。 对 于 初学 者 来 
说 ， 一 方面 ，Wamp 集成 的 环境 虽然 有 很 多 地 方 没有 自己 完全 安装 的 那样 全 面 ， 但 是 已 经 
足够 应 用 ; 另 一 方面 ， 自 己 逐 个 下 载 、 配 置 环境 的 确 非常 繁琐 ， 对 于 大 部 分 用 户 来 讲 是 完 


全 没有 必要 的 。 
本 书 使 用 的 Wamp 5 可 以 在 PHP 的 专业 网 站 上 下 载 ， 推 荐 http://php100.com/， 下 面 讲 
解 下 载 Wamp 5 的 过 程 。 
(1) 打开 网 站 http:/php100.com/, 如 图 1.5 所 示 , 在 上 面 的 分 类 栏 中 找到 “相关 下 载 ”。 
网 nlon 中 文 网 - 中 国 第 一 档 PE 资源 分 享 门户 - Wndows Iaternet Explorer [=15 me) 
GO hs /rin em -Bx |[sh 


文件 中 编辑 EE) 查看 如 收 若 天 (工具) 帮助 0 


将 收藏 天 狗 FIP100 中 文 网 - 中 国 第 一 档 PiF 资 源 分 享 门户 从 "国耻 出 页 面 和 DD， 安 全) 工具 中 -大 » 


9/Y1 频 
“关于 php 后 台 哥 陆 问 题 ( 嫩 蛙 账 


是 ams 


动态 语言 应 该 有 多 动态 ? 


* [7 次 讯 ] Yet 前 请 工程 师 的 ”第 二 春 ” 

“DammLs] mLs 能 否 闫 本 传 统 Yebh 应 用 ? 

， [IT 资讯] 百度 “ 涉 腐 ”: 内 部 员工 有 伟 央 

“ [IT 责 讯 ] 20 年 前 的 今天 -第 一 张 网 页 三 生 

* [IT 资讯 ] 老 折 程序 员 一 一 徒手 实现 伟大 成 
EPs 


故 辜 ]OO 乱 眉 傣 
与 天 无 理由 迟 计 


< 地 现在 购买 ， 更 字 免 费 升级 
里 云 服务 器 ,免费 升级 不 加 价 


2 


“90 要 录 出 锚 ;redirect 

“以 下 瑟 陆 代码 实 全 上 有 什么 问 
“关于 上 传 原理 的 问题. 
jamesaght sm 

“文章 任意 位 置 随机 加 入 特 ; 


my < 结果 的 问题 求助 ~ 


 @ Internet 


图 1.5 PHP100 中 文 网 


(2) 单 击 “ 相 关 下 载 ” 超 链接 ， 进 入 下 载 页 面 ， 如 图 1.6 所 示 。 


» 
和 折 l00% = 


(3) 在 “热点 内 容 ” 栏 中 找到 WampServer 2.1a (为 Wamp 5 的 一 个 版 本 ) 或 在 工具 
下 载 中 查找 ， 单 击 进入 下 载 界面 进行 下 载 。 
(4) 下 载 完 成 后 进行 解压 安装 ， 方 法 与 安装 一 般 软 件 一 样 。 


\V / 
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大 下 载 炳 首 - Windows Thtarrat eplorar 


一 


GO Re /em ry 


EI 四 日 


这 路 训 下。 | 才 下 载 有 着 


文件 包 编辑 加 、 查 看 WD 忆 训 天 册 工具 四 和 助 四 


芥 = 园 二 口 生日 - ”ID- 四- ”| 


rs 
PHP100 


PHP100 三 不 条 约 “投入 
PHp 李 职 本 得 | 项目 区 示 | 亚 要 区 训 LE 
PHP 海 源 分 可 门户 。 PHP 丙 罗 | 网 5 概 板 1 插 首 关 检 | 其 估 志 村 工具 下 和 | 稚 实 


国内 最 专业 的 PHP 培 训 机 构 
创 恩 教 育 chuangen.com 


间 wampserver 5 和 十 Ver 2 
卓 Wampserver 2.13 多 语 言 信 成 忆 
雪 。 回 EdipsepHp Studio 3.0 末代 中立 中 
MM Edpsephp sudb 1.2.2 ( EFP) 
图 PHP 53.6/ PHP 52.17 T 吉 与 
软 绩 惠 : .| 巴 权 放 式 : 鞠 安 。 羡 Edipsephp tudo 2008 v1.0 中 3 
国 Wanpserver 5 入 四 二 


9 Zerver2 for PHP100 集成 开发 环境 20114136 20287Ik 
条 成 了 PHP /Myst | NGINX / Nemcaane5 , 名 5 三 半 导 @ 后 


图 1.6 PHP100 下 载 页 面 


2. Wamp 的 配置 

Wamp 的 安装 非常 简单 ， 在 安装 完成 之 后 需要 用 户 自己 配置 文件 ， 以 方便 使 用 。 下 面 
将 详细 讲解 如 何 配置 Wamp。 

(1) 调整 语言 。 

程序 安装 好 之 后 ,默认 语言 为 英语 ,为 了 符合 大 家 的 语言 习惯 ,可 以 把 语言 改 成 中 文 ， 
方法 是 在 系统 托盘 中 右 击 Wamp 的 图 标 ， 按 图 1.7 所 示 选 择 chinese。 


chinese_trad 
eroatian 
crech 
dunish 
deutseh 
dutch 

V oalish 
estonian 
fimish 
french 
eek 
hunesrian 
italian 
orwegian 
occitan 
polish 
portuguese 
rossian 
spanish 
swedish 
turkish 


图 1.7 调整 语言 图 示 


(2) 配置 WampServer 的 www 目录 。 
WampServer 安装 完成 之 后 ， 默 认 的 www 目录 在 程序 安装 所 在 文件 夹 的 www 子 文件 \、《/ 
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夹 下 ， 为 了 管理 方便 ， 一 般 将 该 目录 设置 为 用 户 自己 的 web 主 目录 ,假设 web 主 目录 的 路 
径 为 D:\web\， 设置 方法 如 下 : 

@ 首先 进入 程序 所 在 的 文件 夹 , 找到 scripts 文件 夹 , 进入 后 有 一 个 名 为 config.inc.php 
的 文件 ， 如 图 1.8 所 示 。 


文件 中 a 二 看 如 ”收藏 中 工具 四 帮助 ) 


@ 扣 -日 - 依 记 时 已 zx| 国 -回信 让 XXXY 


地 址 [Ec Wanp\seripts -日 


deleteAlias. 
深 和 证? 区 | pe xf Sy. 国 ES | 加 | 给 人 
2 1 了 1 
Li onlineOffline. refresh swit achelod. 
区 深 允 区 | 深交 _ 玉生 了 w 祷 伴 3 
2 Er 1 
swit acheVers, swit Versi. ‘switchPhpExt. switchPhpPar an. 
区 | ?ex 区 | 这 六 a 吏 Er 
1 8 1 2 到 1 
ts i testPortForInsta, wanpserver, 1ib. 
BE 文件 加 | 严 三 Pi 文件 从 id 
1 1 了 


图 1.8 scripts 文件 夹 


@ 右 击 该 文件 ， 在 弹出 的 快捷 菜单 中 选择 用 记事 本 程序 打开 此 文件 ， 找 到 如 图 1.9 所 
示 选 中 的 部 分 代码 或 直接 使 用 查找 功能 进行 查找 , 默认 为 安装 目录 的 www 文件 夹 , 将 “=” 
后 面 内 容 修 改 为 如 图 1.10 所 示 即 可 。 


[3 


文件 @) 有 

$c_apacheExe = qc. _apacheversiorDr, yapache' qwampConf 

[epecheVersion ~ fwem Peer pach ‘apacheExeDir"],/, 人 apacheExeFle]); 

$c_phpConr $c_apacheVersionDir. /apache'.$w: 

Le ‘7.$wampConf['apacheExeDr"]. on fFie]; 

$c_mysqExe = $c_mysqlversionDir. /mysql'. $wampConfT'mysqlvVersion'].'/.$wampConf 

[mysqExeDr].7.$wampConft mysqExeFie]; 

$c_mysqlConfFie = $c_mysqlVersionDir./mysql'. $wampC: 

[mysqyerslon].7.$wampConf en mysqlconfFie ]; 

$c_phpExe = $c_phpVersionDr. $c_phpClVersion.'/.$wampConff'phpExeFie"]; 

Ens $c_phpVersionDr. ett $c_ hpiVersion.’. $mampCon[ PhpCiFie]， 
mysqiConsole = $c_mysqlvVersionDir,/mysql', $c_mysqlversion,'/.$wampConf 

tt ‘Jmysql.exe'; 


SphpExtDr = 4c_phpyerslorDr,,php',4wampconffphpyerson] yext/'; 


| es = 入 i 


图 1.9 安装 目录 代码 图 示 


文件 四 ry 格式 0) 查看 QD 才 助 0 
[mysqExeDr]./ eco mysqExeFie]]; 


.fphp'. $c_phpClve 由 
$c_mysqlconsole = $c_mysqlVersionDir. /mysq'. $c_mysqVersion.'/. $wampConf 
[mysqExeDr]ymysqexe'; 


人 人 人 ee OPT Pn ‘fextf’; 
dhelpFie = InstalDir.'/ amp5.chl 
Dweb 


Ne 图 1.10 修改 www 主 目 录 代码 
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存在 被 设置 的 路 径 ， 和 否则 会 在 打开 时 出 错 。 


/说 明 


这 里 所 提 到 的 www 目录 纯 属 为 了 简化 管理 www 目录 而 配置 ， 并 不 影响 Web 服务 的 
主 目录 。 这 里 只 是 介绍 一 下 方法 ， 在 本 书 中 如 无 特殊 需要 均 保 持 默 认 目 录 。 


(3) 配置 Apache Web 服务 器 。 
因为 Wamp 安装 好 之 后 直接 支持 PHP 页 面 , 文件 解释 类 型 都 已 经 添加 完毕 ， 所 以 不 需 
要 太 多 的 设置 ， 这 里 只 设置 主 目录 的 位 置 和 主页 的 文件 名 即 可 ， 另 外 再 介绍 一 下 如 何 配置 
虚拟 目录 (Alias 目录 ， 也 叫 别名 目录 )。 
Q@ 设置 主 目录 。 
单 击 系统 托盘 中 的 WampServer 图 标 ， 选 择 Apache 一 httpd.conf 选项 ， 如 图 1.11 所 示 。 


秆 厅 白 W 有 服务 0 
切 和 到 在 本 村 帮 0) 


国 hseie 访问 日 去) 


图 1.11 设置 Apache Web 服务 器 
配置 文件 会 自动 以 记事 本 的 方式 打开 ， 找 到 如 图 1.12 所 示 选 中 的 代码 ， 该 代码 是 要 设置 
的 Web 主 目录 , 客户 访问 域名 或 者 IP 时 , Apache Web 服务 器 会 在 该 文件 夹 检 索 相 应 的 文件 。 


[EE | 
Windows 路 径 里 面 的 “\ ( 反 斜 杠 ) ”都 要 替换 成 “/ ( 正 斜 杠 ) ”， 路 径 外 面 的 双 引 
号 要 保留 。 


which you whl serve your 
en from thE 


rertory but 


图 1.12 httpd 代码 1 N\ YL/ 
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还 有 一 条 代码 ， 其 中 设置 的 目录 要 和 上 面 所 设置 的 目录 一 致 ， 如 图 1.13 所 示 。 


ET) 
文件 中 编辑 下 ) 格式 人 @) 查看 帮助 0 
# particular features to be enabled - otsomet gs noterhhges 


# you might expect, make sure that you have specificaly enabled 
# below. 
La 


天 
# This should be changed to whatever you set DocumentRoot to. 
| 
<Drectory NEST 
# 


# Possble values for the Options drective are "None”, "AI 

# of any combination of 

# Indexes Indudes FolowSymLinks SymLinksifOwnerMatch ExecCGI Multiviews 
关 


# Note that "MultiViews" must be named *explcitly* — "Options Al" 
# doesn't give lt to you. 
# 


# The Options directive fs both complicated andimportant Please see 


图 1.13 httpd 代码 2 


WampServer 默认 的 网 站 起 始 页 面 为 mdex.php、index.php3、index.html、index.htm， 客 

户 在 访问 服务 器 时 , Apache Web 服 务 器 会 自动 在 web 主 目录 里 寻找 列表 中 相 匹 配 的 文件 名 ， 

按 优先 级 高 低 返 回 给 客户 。 例 如 ，web 主 目录 里 既 有 index.php 文件 ， 又 有 index.html 文 

件 ， 那 么 Apache Web 服务 器 会 执行 mdex.php， 并 将 执行 结果 传送 给 客户 ， 而 不 会 自动 传 

送 index.html。Apache Web 服务 器 还 允许 用 户 自 定义 起 始 页 面 的 文件 名 和 优先 级 ， 设 置 方 

法 为 :找到 如 图 1.14 所 示 的 代码 ， 在 DirectoryIndex 后 面 添加 主页 的 文件 名 ， 名 称 之 间 用 
空格 隔 开 ， 优 先 级 从 左 到 右 依次 递减 。 

加 httpa eonf -记事 本 


人 
文件 四 编辑 名 档 式 0) 查看 如 福 助 0 


# 

# DirectoryIndex: sets the fle that Apache wi serve if a drectory 
#1s requested. 

# 


rn 


天 
# The folowing ines prevent .htaccess and htpasswd fies fiom beng 
# Viewed by Web cienits. 


并 
<FiesMatch "~^\ht"> 


图 1.14 优先 级 代码 图 示 

@ 设置 虚拟 目录 (Alias 目录 )。 

一 般 设 置 了 web 主 目录 后 ， 该 目录 下 的 结构 会 随 之 一 并 应 用 于 Web 服务 。 例 如 ， 在 
web 主 目录 匠 中 有 admin 文件 夹 ， 其 中 包含 一 个 admin_ index.php 文件 ， 那 么 可 以 通过 输 
入 http:/localhostadmin/admin index.php 来 执行 该 页 面 。 然而 , 为 了 方便 管理 庞大 的 应 用 系 
统 ， 有 时 候 会 把 不 同 的 应 用 放 到 不 同 的 文件 夹 下 , 并且 该 文件 夹 不 在 web 主 目录 中 。 那么 ， 
可 以 通过 映射 一 个 虚拟 目录 来 达到 相同 的 效果 。 具 体操 作 如 下 。 


单 击 系统 托盘 中 的 WampServer 图 标 , 在 “Alias 目录 ”菜单 项 中 选择 “添加 一 个 Alias”， 
\yy 如 图 1.15 所 示 。 
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图 1.15 


辕 http://aeeahestyphpeysania/ » 
baaz/ 


http://1ocdlhe 
| 。 RE 并 关 态 2) 


添加 Alias 目录 示例 


出 现 如 图 1.16 所 示 的 界面 ,在 冒号 后 边 输入 虚拟 目录 名 称 ( 可 以 和 真实 目录 名 称 不 同 )， 


这 里 以 admin 为 例 。 


wanp\binVphp\php5. 了 .3Vphp_exe 


图 1.16 


输入 虚拟 目录 名 称 


按 Enter 键 ， 输 入 要 有 映射 的 真实 地 址 。 


若 Windows 里 的 文件 夹 为 cvadmin\， 这 里 应 该 输入 c:/admin/， 


nd make http: 


le:/test/ 


: c:/adnin, 


国 ::\wwp\bin\php\php5.3 3\php. exe 


如 图 1.17 所 示 。 


-上 口 |x| 


图 1.17 输入 映射 地 址 


项 目 1 初步 认识 PHP 及 相关 配置 | Se 


按 Enter 键 后 即 可 创建 成 功 ， 按 任意 键 退出 创建 程序 ， 如 图 1.18 所 示 。 


exAwampAbinAphpAphp5. 3. 3\php. exe -ID|x 


nter the destination of your alias. 
IFor example,. 


"cs/test/’ 
Would make http://localhost/adnin/ point to 
Ic:/test/ 


: ci:/adnin/ 


Alias created. Press Enter to exit... 


图 1.18 创建 成 功 
要 使 设置 生效 ， 需 要 重新 启动 Apache Web 服务 器 ,但 是 WampServer 没有 提供 单独 停 
止 某 一 服务 的 选项 ， 所 以 选择 “重新 启动 所 有 服务 ”。 
注意 一 个 特例 : 假设 web 主 目录 中 有 admin 文件 夹 ， 而 恰巧 用 户 又 设置 了 一 个 名 为 
admin 的 虚拟 目录 ， 那 么 Apache Web 服务 器 会 打开 哪个 文件 夹 中 的 内 容 呢 ? 再 假如 ， 在 
web 主 目 录 的 admin 文件 夹 中 有 一 个 名 为 Admin_ index.php 的 文件 ， 而 在 名 为 admin 的 虚拟 
也 有 Admin_index.php 文件 ,那么 Apache Web 服务 器 又 会 执行 哪 一 个 呢 ? 经 过 
ei 结果 是 如 果 没 有 在 虚拟 目录 里 面 找 到 Admin index.php， 那 么 就 会 自动 在 web 主 目录 
下 的 admin 文件 夹 下 查找 ， 如 果 都 没 找到 ， 就 会 提示 “HTTP404 文件 未 找到 ” 如 果 找 到 
就 执行 。 反 之 ， 没 有 在 web 主 目录 的 admin 文件 夹 找到 文件 ， 服 务 器 就 会 去 虚拟 目录 里 寻 
找 ， 若 两 个 目录 中 有 相同 文件 名 的 文件 ， 虚 拟 目录 的 优先 级 高 ， 会 执行 虚拟 目录 下 的 文件 。 
@ 删除 虚拟 目录 (Alias 目录 )。 
删除 虚拟 目录 (Alias 目录 ) 的 方法 为 : 单 击 
系统 托盘 中 的 WampServer 图 标 ， 选 择 Apache 一 
“Alias 目录 ”一 http:/localhostadmin/〈 要 删除 的 
Alias 目录 ) 一 Delete alias 命令 ， 如 图 1.19 所 示 。 


程序 会 提示 是 否 真 的 要 删除 该 Alias 目录 ， 如 ee 二 人 二 二 ， 
果 确 认 删 除 , 输入 yes 后 按 Enter 键 即 可 , 如 图 1.20 hosche 访问 B 志 C) 。 国 hep pn 
所 示 。 ps 

同样 ， 在 删除 虚拟 目录 后 ， 要 重启 所 有 服务 才 TS 
能 生效 。 图 1.19 删除 虚拟 目录 图 示 
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国 -ee\bin\php\php5 3 3vphp exe -Io|x| 


图 1.20 删除 虚拟 目录 操作 


f、 
了 /说明 
本 节 中 的 配置 方法 只 是 为 了 方便 管理 ， 对 于 初学 者 用 处 不 大 ， 建 议 安装 Wamp 后 保持 
默认 设置 即 可 。 对 从 事 编程 的 读者 来 讲 ， 重 新 配置 有 助 于 自己 编程 的 管理 及 提高 效率 ， 可 
以 按照 上 述 方法 进行 配置 


1.2.3 editplus 的 安装 
文本 编辑 器 的 下 载 也 非常 只 要 在 搜索 引擎 中 搜索 editplus 即 可 。 在 这 里 ， 简 单 
介绍 一 下 editplus 的 下 载 与 安装 。 
本 书 中 所 用 的 文本 编辑 器 是 在 XP 下 载 乐 园 下 载 的 , 网址 是 http://www.xp500.com/。 如 
图 1.21 所 示 ， 在 搜索 文本 框 中 输入 editplus， 然 后 选择 相应 的 版 本 即 可 进入 下 载 界 面 ， 如 
图 1.22 所 示 。 
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P 系 统 下 载 ET 系统 软件 周 挤 行 。 系统 软件 推荐 榜 。 。 二 人 
了 q * [windows7] 系统 之 家 Ghost WINT SPF1 旗舰 装机 版 "5.0 
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关键 字 请 匆 往 版 本 号 Be” re 


editplus 3.21. 761 之 后 的 版 本 ， 与 之 前 的 版 本 在 程序 设计 上 有 较 大 的 改变 按照 之 前 的 汉化 和 解决 方法 ,已 经 不 能 完美 解决 问题 4 
文本 文件 ， 当 “另存 为 ”、 并 在 文件 名 输入 框 里 点 忌 标 右键 时 ， 右 键 菜单 为 英文 。 好 多 网 友 反 反 请 认为 没有 汉化 完整 ， 其 实 这 和 汉化 完全 
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editplus 破 解 版 与 之 前 的 版 本 在 程序 设计 上 有 较 大 的 改变 按照 之 前 的 汉化 和 破解 方法 ， 
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图 1.22 editplus 下 载 页 面 


下 载 完 成 后 进行 解压 安装 ， 如 图 1.23 所 示 。 一 直 单 击 “ 下 一 步 ” 按 钮 按 提 示 方 法 操作 


即 可 。 
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图 1.23 ”editplus 安装 向 导 


任务 实施 


正确 下 载 、 安 装 、 配 置 PHP 编程 开发 相关 环境 及 编写 工具 。 


练习 
PHP 开发 环境 主要 包括 什么 ? 


欢迎 使 用 EditPlus 3 安装 向 导 
De 


i 
ee 


单 击 “ 下 一 步 ” 继续 ,或 单 击 “ 取 消 ” 退 出 安装 程序 。 
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| 知识 点 、 技 能 点 


> PHP 中 的 数据 类 型 

> PHP 中 的 变量 与 常量 
> ”PHP 中 的 运算 符 

> PHP 中 的 表达 式 

> PHP 中 的 流程 控制 语句 


掌握 和 理解 PHP 中 的 数据 类 型 
掌握 PHP 中 的 变量 与 常量 


掌握 PHP 中 的 表达 式 
掌握 和 理解 PHP 中 的 流程 控制 语句 


> 
> 
> 掌握 PHP 中 的 运算 符 
> 
> 


教学 基础 要 求 


> 掌握 和 理解 PHP 中 的 数据 类 型 

> 掌握 PHP 中 的 变量 与 常量 

> 掌握 PHP 中 的 运算 符 

> 掌握 PHP 中 的 表达 式 

> 掌握 和 理解 PHP 中 的 流程 控制 语句 


任务 1 了 解 PHP 中 数据 关 型 、 常 音 与 变量 


任务 描述 

数据 类 型 、 常 量 与 变量 是 构成 程序 的 基石 ， 所 以 每 种 编程 语言 中 都 会 有 本 类 语言 所 对 
应 的 数据 类 型 、 常 量 与 变量 。 作 为 一 门 网 络 编程 语言 ，PHP 也 不 例外 。 本 任务 将 详细 介绍 
PHP 中 数据 类 型 、 常 量 与 变量 的 知识 。 通过 本 任务 的 学 习 , 读者 会 了 解 PHP 中 的 数据 类 型 ; 
掌握 什么 是 常量 、 变量 ; 在 PHP 中 如 何 使 用 预定 义 常量 与 变量 , 如 何 自 定义 常量 与 变量 等 。 

知识 汇总 


2.1.1 PHP 中 的 数据 类 型 


数据 类 型 是 学 习 一 种 编程 语言 最 基础 同时 也 是 极为 重要 的 一 部 分 ， 每 一 位 编程 人 员 都 
要 对 数据 类 型 进行 深入 的 学 习 和 透彻 的 研究 。 下 面 就 对 PHP 中 的 数据 类 型 进行 介绍 。 

首先 介绍 一 下 PHP 支持 的 8 种 原始 类 型 。 

回 4 种 标量 类 型 : 

> boolean 〈 布 尔 型 )， 理 解 为 真 假 型 

> integer ( 整 型 ) 

> float( 浮 点 型 ， 也 作 double)， 理 解 为 小 数 型 
> string (字符 串 ) 

回 ”两 种 复合 类 型 ; 

> array (数组 ) 

> object (对象) 
回 ”两 种 特殊 类 型 ; 

resource (资源 ) 

> NULL ( 空 值 ) 

在 PHP 中 主要 就 是 这 8 种 数据 类 型 ， 当 然 对 于 数据 类 型 之 间 的 综合 应 用 ， 为 了 确保 代 
码 的 易 读 性 ， 还 定义 了 3 种 伪 类 型 : mixed (混合 )、number 数字) 和 callback〔 回 馈 )， 
但 这 只 是 数据 类 型 之 间 的 交叉 混合 使 用 ， 是 建立 在 以 上 8 种 数据 类 型 基础 上 的 ， 在 这 里 不 
再 详细 讲述 ， 如 果 读 者 想 要 深入 学 习 相关 知 识 ， 可 以 在 网 络 上 搜索 相关 资源 或 参考 PHP 
手册 。 

下 面 详 细 介绍 PHP 中 的 8 种 基本 数据 类 型 。 

1. boolean (布尔 型 ) 

布尔 型 是 最 简单 的 数据 类 型 ， 它 表达 了 真 值 ， 可 以 为 TRUE 或 FALSE (注意 : 布尔 类 
型 是 PHP 4 引进 的 )， 下 面 是 赋值 为 布尔 型 的 示例 。 赋 值 关 键 字 TRUE 或 FALSE 是 不 区 分 


大 小 写 的 。 
\y/ 
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<?php 
$foo=True; // 给 foo 赋值 为 真 
?> 


要 将 一 个 值 转换 成 boolean， 可 以 用 bool 或 者 boolean 来 强制 转换 。 但 是 很 多 情况 下 不 
需要 强制 转换 ， 因 为 当 运算 符 、 函 数 或 者 流程 控制 需要 一 个 boolean 参数 时 ， 该 值 会 被 自 
动 转换 。 
转换 为 boolean 时 ， 以 下 值 被 认为 是 FALSE: 

布尔 值 FALSE 
整 型 值 0 
浮 点 型 值 0.0 
空白 字符 串 和 字符 串 "0" 
没有 成 员 变量 的 数组 
没有 单元 的 对 象 
特殊 类 型 NULL (包括 尚未 设 定 的 变量 ) 
所 有 其 他 值 都 被 认为 是 TRUE (包括 任何 资源 )。 
【 例 2.1】 
<2php 
echo gettype((booD)""); 
echo gettype((booD1); 
echo gettype((bool)-2); 
echo gettype((booD)0); 
echo gettype((bool)0.0); 
echo gettype((bool) "0"); 
echo gettype((bool) "foo"); 
echo gettype((bool) "3.14e"); 
echo gettype((bool)array(12)); 
echo gettype((booDarrayO); 


?> 


QARANRARAAK 


以 上 代码 中 ，echo 是 输出 字符 串 内 容 的 指令 ，gettype 是 取得 变量 类 型 的 指令 ，gettype 
后 面 括号 中 的 内 容 是 更 改 数据 类 型 的 命令 。 
上 面 代码 输出 的 内 容 如 图 2.1 所 示 。 


转化 为 布尔 什 
GO 昌 - 卓 locabostz 国内 |] | 人 
席 收藏 天 。 病 苇 化 为 布尔 逢 
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图 2.1 转化 为 布尔 值 执行 结果 


输出 的 结果 是 后 面 各 个 类 型 数据 更 改 之 后 的 数据 类 型 。 对 于 数据 类 型 的 转换 同样 适用 
于 其 他 的 数据 类 型 。 二 
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2. integer ( 整 型 ) 
一 个 integer 是 集合 Z = {.… -2, -1, 0, 1, 2, .…} 中 的 一 个 数 。 
整 型 值 可 以 用 十 进 制 、 十 六 进 制 或 八进制 符号 指定 ， 前 面 可 以 加 上 可 选 的 符号 “-” 


或 bo 

如 果 用 八进制 符号 ， 数字 的 前 面 必须 加 上 0; 用 十 六 进 制 符号 ,数字 前 面 必须 加 上 0x， 
如 例 2.2 所 示 。 

【 例 2.2】 

<?php 

$a=123; 1/ 十进制 数 

$a=-123; // 一 个 负数 

$a=0123; /八进制 数 〈 等 于 十 进 制 的 83) 

$a=0x1A; 1/ 十 六 进 制 数 (等 于 十 进 制 的 26) 

?> 


例 2.2 是 对 a 赋值 各 种 整 型 数据 。 

需要 注意 整数 液 出 的 问题 ， 整 数 溢出 指 的 是 一 些 很 大 的 数字 超出 了 integer 的 范围 。 

如 果 指 定 一 个 数 超出 了 integer 的 范围 ， 将 会 被 解释 为 oat。 同 样 ， 如 果 执行 的 运算 结 
果 超 出 了 integer 范围 ， 也 会 返回 float， 如 例 2.3 所 示 。 


【 例 2.3】 
<2php 
S$large_number = 2147483647; 
var_dump($large_number); // 输 出 为 int(2147483647) 


S$large_number = 2147483648; 
var_dump($large_ numben); 1/ 输出 为 float(2147483648) 


// 同 样 也 适用 于 十 六 进 制 表示 的 整数 

var_dump( 0x80000000 ): /输出 为 float(2147483648) 
$million = 1000000; 

S$large_number = 50000 * $million:; 


var_dump($large_number); // 输 出 为 float(50000000000) 
4 


执行 结果 如 图 2.2 所 示 。 


int (2147483647) float (2147483648) float 
(2147483648) float (50000000000) 


图 2.2 整数 溢出 执行 结果 
\V / 
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另外 ，PHP 中 没有 整除 的 运算 符 。1/2 产生 出 浮 点 数据 ， 用 户 可 以 总 是 舍弃 小 数 部 分 ， 
或 者 使 用 roundO 函 数 。 
【 例 2.4】 


<2php 

var_dump(14/3); // 输 出 float(4.6666666666667) 
var_dump((int) (14/3)); // 输 出 int(4) 
var_dump(round(14/3)): // 输 出 float(5) 

?> 


输出 结果 如 图 2.3 所 示 。 


[< CIDICIr 
会 收 诚 天 。 蔽 束 除 运 划 


float (4. 6666666666667) int(4) float (5) 


图 2.3 整除 运算 结果 
3.，float ( 浮 点 型 ) 
浮 点 型 (也 称 为 floats、doubles 或 real numbers) 可 以 用 以 下 任何 语法 定义 : 


<2php 
$a=1.234; 
$a=1.2e3; 
$a=7E-10; 
> 


浮 点 数 的 字 长 和 平台 相关 ， 不 过 通常 最 大 值 是 1.8e308， 并 具有 14 位 十 进 制 数 字 的 精 
度 (64 位 IEEE 格式 )。 

需要 注意 的 是 浮 点 数 的 精度 问题 。 显 然 ， 简 单 的 十 进 制 分 数 〈 如 0.1 或 0.7) 不 能 在 不 
丢失 精度 的 情况 下 转换 为 内 部 二 进 制 的 格式 ， 这 就 会 造成 混乱 的 结果 。 例 如 ， 
floor((0.1+0.7)*10) 通常 会 返回 7 而 不 是 预期 中 的 8， 因 为 该 结果 内 部 的 表示 其 实 是 
7.9999999999...。 

这 和 一 个 事实 有 关 ， 那 就 是 不 可 能 精确 地 用 有 限 位 数 来 表达 某 些 十 进 制 分 数 。 例 如 ， 
十 进 制 的 2/3 变 成 了 0.6666666...。 所 以 永远 不 要 相信 浮 点 数 结果 精确 到 了 最 后 一 位 ， 也 永 
远 不 要 比较 两 个 浮 点 数 是 否 相 等 。 如 果 确 实 需要 更 高 的 精度 ， 应 该 使 用 任意 精度 数学 函数 
库 或 gmp 函数 库 。 

4. string (字符 串 ) 

string 是 一 系列 字符 。 在 PHP 中 ， 字 符 与 字 节 是 一 样 的 ， 也 就 是 说 ， 一 共有 256 种 不 
同 字符 的 可 能 性 ， 这 也 暗示 PHP 对 Unicode 没有 本 地 支持 。 这 样 ， 一 个 字符 串 变 得 非常 巨 
大 也 没有 问题 ，PHP 没有 给 字符 串 的 大 小 强加 实现 范围 ， 所 以 不 必 担 心 长 字符 串 。 

字符 串 有 3 种 定义 方法 : 单 引号 、 双 引号 、 定 界 符 。 < 
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(1) 单 引号 : 指定 一 个 简单 字符 串 的 最 简单 的 方法 是 用 单 引号 〈") 括 起 来 。 要 表示 
一 个 单 引号 ， 需 要 用 反 斜 线 (\) 转 义 ， 和 很 多 其 他 语言 一 样 ， 如 果 要 在 单 引 号 之 前 或 字符 
串 结 尾 出 现 一 个 反 斜 线 ， 需 要 用 两 个 反 斜 线 表示 。 


如 果 试图 转 义 任何 其 他 字符 ， 反 斜 线 本 身 也 会 被 显示 出 来 ， 所 以 通常 不 需要 转 义 反 儿 
线 本 身 。 | 

(2) 双 引 号 : 可 以 用 双 引 号 〈") 括 起 字符 串 ，PHP 中 特殊 字符 的 转 义 序列 如 表 2.1 
所 示 。 

表 2.1 PHP 中 特殊 字符 转 义 序列 
序 列 含义 

un 换行 (LF 或 ASCI 字符 0x0A (10) ) 

Yr 回 车 (CR 或 ASCIT 字符 0x0D (13) ) 

vt 水 平 制 表 符 (HT 或 ASCI 字符 0x09 (9) ) 

\ 反 斜 号 

\$ 美元 符号 

Yr 双 引 号 

\[0-7]{1,3} 此 正则 表达 式 序列 匹配 一 个 用 八进制 符号 表示 的 字符 

\x[0-9A-Fa-f]{1,2} 此 正则 表达 式 序列 匹配 一 个 用 十 六 进 制 符号 表示 的 字符 


此 外 ， 如 果 试 图 转 义 任何 其 他 字符 ， 反 和 斜 线 本 身 也 会 被 显示 出 来 。 双 引号 字符 串 中 的 
变量 名 会 被 变量 值 奉 代 。 

(3) 定 界 符 : 另 一 种 给 字符 串 定 界 的 方法 是 使 用 定 界 符 语法 (<<<)。 应 该 在 <<< 之 
后 提供 一 个 标识 符 ， 然 后 是 字符 串 ， 最 后 是 同样 的 标识 符 结束 字符 串 。 结 束 标识 符 必 须 从 
行 的 第 一 列 开始 。 同 样 ， 标 识 符 也 必须 遵循 PHP 中 其 他 任何 标签 的 命名 规则 : 只 能 包含 字 
母 数字 下 划 线 ， 而 且 必须 以 下 划 线 或 非 数 字 字 符 开 始 。 

很 重要 的 一 点 必须 指出 ， 结 束 标识 符 所 在 的 行 不 能 包含 任何 其 他 字符 ， 可 能 除了 一 个 
分 号 (;) 之 外 。 这 意味 着 该 标识 符 不 能 被 缩 进 ， 而 且 在 分 号 之 前 和 之 后 都 不 能 有 任何 空格 
或 制 表 符 。 同 样 重要 的 是 要 意识 到 在 结束 标识 符 之 前 的 第 一 个 字符 必须 是 所 使 用 操作 系统 
中 定义 的 换行 符 ， 如 在 Macintosh 系统 中 是 tY。 如 果 破 坏 了 这 条 规则 ， 则 它 不 会 被 视 为 结束 
标识 符 ，PHP 将 继续 寻找 下 去 。 如 果 找 不 到 合适 的 结束 标识 符 ， 将 会 导致 一 个 在 脚本 最 后 
一 行 出 现 的 语法 错误 。 

定 界 符 文 本 与 双 引 号 字符 串 一 样 ， 只 是 没有 双 引 号 。 这 意味 着 在 定 界 符 文 本 中 不 需要 
转 义 引号 ， 不 过 仍然 可 以 用 表 2.1 中 的 转 义 代码 。 变 量 会 被 展开 ， 当 在 定 界 符 文本 中 表达 
复杂 变量 时 和 字符 串 一 样 也 要 注意 。 
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果 的 类 型 和 值 : 


如 果 和 包括 .、e 或 EE 中 任何 一 个 字符 ,字符 串 被 当 作 float 来 求 值 ， 否 则 ， 被 当 作 整 数 。 
该 值 由 字符 囊 最 前 面 的 部 分 决定 。 如 果 字 符 囊 以 合法 的 数字 数据 开始 ， 就 用 该 数字 作为 其 
值 ， 否 则 其 值 为 0。 合 法 数字 数据 由 可 选 的 正 负 号 开始 ， 后 面 跟着 一 个 或 多 个 数字 ( 可 选 
的 包括 十 进 制 分 数 ) , 然后 是 可 选 的 指数 。 指数 是 一 个 e 或 者 巨 后 面 跟着 一 个 或 多 个 数字 。 


【 例 2.5】 

<2php 

$foo=1+"10.3"; //$foo is float (11.3) 
echo "\$foo 一 $foo: type is " . gettype ($foo) . "<br />\n"; 
$foo= 1+"-1.3e3"; //$foo is float (-1299) 
echo "\$foo=—$foo; type is " . gettype ($fo0) . "<br />\n"; 
$foo = 1 + "abcd-1.3e3"; //$foo is integer (1) 
echo "\$foo=—=$foo; type is " . gettype ($fo0) . "<br />\n"; 
$foo = 1 + "abcd3"; //$foo is integer (1) 
echo "\$foo=—$foo; type is " . gettype ($fo0) . "<br />\n"; 
$foo = 1 + "10 abcde"; //$foo is integer (11) 
echo "\$foo=——$foo; type is " . gettype ($foo) . "<br />\n"; 
$foo = 2+ "10.2 abcde"; //$foo is float (12.2) 
echo "\$foo 一 $foo: type is " . gettype ($foo) . "<br />\n"; 
$foo = "10.0 abcd"+1; //$foo is float (11) 
echo "\$foo=——$foo; type is " . gettype ($foo) . "<br />\n"; 
$foo = "10.0 abcd "+ 1.0; //$foo is float (11) 
echo "\$foo=—$foo; type is " . gettype ($foo) . "<br />\n"; 
> 


运行 结果 如 图 2.4 所 示 。 


字符 束 转换 为 数值 - Window 
例外 回 locdhost :加 | 刀 |X| 调 
宣 收 庆 天。 蔽 字符 串 转 执 为 数值 


$f00==11. 3; type is double 
$foo==-1299; type is double 
foo==1; type is integer 
$foo==1; type is integer 
$foo==11; type is integer 
$foo==12. 2; type is double 
$f00=11; type is double 
$f00=11; type is double 


图 2.4 字符 串 转换 为 数值 
5. array (数组 ) 


PHP 中 的 数组 实际 上 是 一 个 有 序 图 。 图 是 一 种 把 values 映射 到 keys 的 类 型 。 此 类 型 
二 电 浊 


.0 高 等 职业 教育 “十 二 五 ”规划 教材 一 中 上 


一 项目 2 PHP 编程 基础 学 习 国 


在 很 多 方面 做 了 优化 ， 因 此 可 以 把 它 当 成 真正 的 数组 来 使 用 ， 或 列表 〈 矢 量 )、 散 列表 〈 是 
图 的 一 种 实现 )、 字 典 、 集 合 、 栈 、 队 列 以 及 更 多 可 能 性 。 因 为 可 以 用 另 一 个 PHP 数组 作 
为 值 ， 也 可 以 很 容易 地 模拟 树 。 

可 以 用 array 语言 结构 来 定义 一 个 array， 它 接受 一 定数 量 用 去 号 分 隔 的 key=>value 参 
数 对 ， 如 下 所 示 : 

<?php 

$a=array('key'=>'abcd',3=>true); 

echo $al'key'];  //abcd 


echo $a[3]; Wl 
J 


其 中 key 和 3 是 数组 a 的 元 素 ，key 被 赋值 为 abcd，3 被 赋值 为 布尔 值 tue。 输 出 结果 
就 是 注释 的 内 容 。 

对 数组 的 操作 将 会 在 数组 型 变量 中 讲述 。 

6. object (对 象 ) 


(1) 对 象 的 初始 化 。 
要 初始 化 一 个 对 象 ， 用 new 语句 将 对 象 实例 到 一 个 变量 中 ， 如 例 2.6 所 示 。 
【 例 2.6】 


<2php 
class foo 
function do-foo0 


} 

$bar=new foo: 
$bar->do-foo(); 
?> 


相关 内 容 将 在 项 目 6 的 类 与 对 象 中 详细 讲解 。 

(2) 转换 为 对 象 。 

如 果 将 一 个 对 象 转换 成 另 一 个 对 象 ， 它 将 不 会 有 任何 变化 ， 如 果 将 其 他 任何 类 型 的 值 
转换 成 对 象 , 内 置 类 stdClass 的 一 个 实例 将 被 建立 。 如 果 该 值 为 NULL, 则 新 的 实例 为 空 。 
对 于 任何 其 他 的 值 ， 名 为 scalar 的 成 员 变 量 将 包含 该 值 ， 例 如 : 

<2php 

$obij=(objecb'abcd': 


echo $obj->scalar; /输出 'abcd' 
?> 


echo"do foo. ": 


7. resource ( 资源) 
/ 一 个 资源 是 一 个 特殊 变量 ， 保 存 了 到 外 部 资源 的 一 个 引用 。 资 源 是 通过 专门 的 函数 来 
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建立 和 使 用 的 。 由 于 资源 类 型 变量 保存 有 为 打开 文件 、 数 据 库 连接 、 图 形 画 布 区 域 等 的 特 
殊 句柄 ， 因 此 无 法 将 其 他 类 型 的 值 转换 为 资源 。 
8. NULL 


特殊 的 NULL 值 表 示 一 个 变量 没有 值 。NULL 类 型 唯一 可 能 的 值 就 是 NULL。 
有 3 种 情况 会 认定 一 个 变量 是 NULL: 被 赋值 为 NULL、 尚 未 被 赋值 、 被 unset。 
NULL 类 型 只 有 一 个 值 ， 就 是 区 分 大 小 写 的 关键 字 NULL。 


2.1.2 PHP 中 的 常量 


常量 是 在 程序 运行 中 值 始 终 不 会 发 生 改变 的 一 类 量 。 在 进行 PHP 编程 时 经 常 要 用 到 这 
类 数据 ， 如 打开 文件 的 文件 名 、 文 件 的 路 径 等 系统 常量 以 及 用 户 自 定义 的 一 些 常量 。 

1， 定 义 和 使 用 常量 

常量 在 使 用 前 必须 定义 ， 否 则 程序 在 执行 时 就 会 出 错 。 在 PHP 中 使 用 defineO 函 数 来 
定义 常量 ， 其 语法 格式 如 下 : 


define("name","value"); 


其 中 的 name 为 定义 常量 的 常量 名 ，value 为 常量 代表 的 值 。 
下 面 通过 一 个 实例 来 介绍 一 下 PHP 中 常量 的 定义 与 使 用 。 
【 例 2.7】 


<html> 

<head> 

<title>PHP 中 常量 的 定义 与 使 用 </title> 
</head> 

<body> 

<2php 

define("abcd","hello world!"): /定义 常量 abcd， 并 赋值 为 hello world! 
echo abcd: 

?> 

</body> 

</html> 


执行 结果 如 图 2.5 所 示 。 


PHP 中 常量 的 定义 与 使 用 - Windovs Int--- 尾 | 大 | 必 ) 
例 转 * 回 locudlhost [ss | X | ce 
会 收 京 天 。 | 籁 Pi 中 常量 的 定义 与 使 用 


hello world! 


图 2.5 常量 定义 代码 执行 结果 
常量 的 命名 不 是 随意 的 ， 必 须 符合 一 定 的 规则 。PHP 中 常量 的 命名 有 以 下 规则 : 合法 
的 常量 名 以 字母 或 下 划 线 开始 ， 后 面 可 跟 任何 字母 、 数 字 或 下 划 线 。 \ 71/ 


一 
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常量 与 变量 的 不 同 之 处 体现 在 以 下 几 个 方面 : 

回 ”常量 前 面 没 有 符号 $， 而 变量 则 必须 以 开头 。 

回 ”常量 只 能 用 define0 函 数 定义 ， 而 不 能 通过 赋值 语句 定义 。 

名 ”常量 可 以 不 用 理会 变量 范围 的 规则 ， 可 以 在 任何 地 方 定义 和 访问 。 

回 ”常量 一 旦 定义 就 不 能 被 重新 定义 或 者 取消 定义 ， 并 且 其 值 不 能 发 生 改变 ， 而 变量 


的 值 可 以 随时 发 生 改 变 。 这 也 是 常量 与 变量 最 根本 的 不 同 。 
回 ”常量 的 值 只 能 是 标量 ， 即 整 型 、 浮 点 型 、 字 符 串 3 种 类 型 。 
2. PHP 中 的 预定 义 常量 
除了 使 用 自 定义 常量 之 外 ，PHP 还 为 用 户 预定 义 了 系统 常量 ， 常 见 的 预定 义 常 量 及 其 


含义 如 表 2.2 所 示 。 
表 2.2 PHP 中 的 预定 义 常量 
常 量 名 说 了 明 
_FILE_ PHP 文件 的 文件 名 
_LINE_ PHP 文件 的 行 数 
PHP VERSION PHP 程序 的 版 本 
PHP OS 执行 PHP 解释 器 的 操作 系统 名 称 ， 如 windows 
TRUE 真 
FALSE 假 
E_ ERROR 最 近 的 错误 处 
E_ WARNING 最 近 的 警告 处 
E PARSE 剖析 语法 有 潜在 问题 处 
E NOTICE 发 生 不 寻常 但 不 一 定 是 错误 处 


下 面 遂 过 一 个 实例 来 实际 应 用 一 下 PHP 中 的 预定 义 常量 。 
【 例 2.8】 


<html> 

<head> 

<title> PHP 中 预定 义 常量 的 使 用 </tile> 
</head> 

<body> 

<?php 

echo" 所 使 用 的 文件 名 是 :"; 
echo_FILE :; 

echo"<br>"; 
echo" 文 件 行 数 是 : "; 
echo_LINE ; 

echo"<br>"; 

echo"PHP 的 版 本 是 :"; 


// 当 前 文件 名 
// 输 出 换行 符 


// 输 出 文件 行 数 


\ Tv echo PHP VERSION: 


// 输 出 PHP 版 本 
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echo"<br>"; 


echo" 所 使 用 的 操作 系统 是 :"; 

echo PHP_OS: /输出 操作 系统 类 型 
?> 

</body> 

</html> 


运行 结果 如 图 2.6 所 示 。 


PHP 中 预定 义 常量 的 使 用 - Windows Interne--- 奈 | 夺 | 医 | 
GO 昌 - 悍 locuhort :加 | 好 |X| 十 
请 收 庆 天。 筷 pe 中 预定 义 御 量 的 全 用 


所 使 用 的 文件 名 是 ，C: \wamp\www\2. 7. php 
文件 行 数 是 ，11 


PHP 的 版 本 是 ，5. 3. 3 
所 使 用 的 操作 系统 是 ，WINNT 


图 2.6 PHP 中 预定 义 常量 的 使 用 


当然 ， 实 际 的 执行 结果 会 因为 使 用 的 操作 系统 、PHP 版 本 的 不 同 而 与 图 2.6 所 示 不 同 ， 
但 一 定 是 所 用 计算 机 上 的 相应 数据 。 
fi 
| 注意 


不 论 是 使 用 自 定义 常量 还 是 系统 预定 义 常量 ， 大 小 写 都 必须 要 一 致 。 如 使 用 系统 预定 
义 常量 时 把 大 写 改 为 小 写 , 就 不 能 正确 返回 预定 义 常 量 PHP VERSION 预定 义 的 PHP 版 本 
号 ， 而 是 返回 给 字符 串 php_vevsion 添加 单 引号 的 提示 。 代 码 如 下 : 

<2php 

echo PHP_VERSION; 

echo"<p>": 

echo php_version: 

> 


运行 结果 如 图 2.7 所 示 。 
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GO-E Tocubost/: 国 || 娘 [x| 窜 
富 收 茂 六 。 | 乱 FIP 中 预定 义 窜 量 的 使 用 


5.3.3 


Notice: Use of undefined constant php_version 
- assumed "php_version in 
C:\wamp\www\2.7.2.php on line 9 
php_version 


图 2.7 PHP 输出 预定 义 常量 区 分 大 小 写 图 示 
由 此 可 见 ， 在 使 用 系统 预定 义 常 量 时 ， 一 定 要 注意 大 小 写 的 问题 。 
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变量 
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PHP 中 的 变量 
是 指 在 程序 运行 过 程 中 其 值 可 以 随时 发 生 改变 的 一 类 值 。PHP 是 一 个 弱 类 型 的 语 


言 ( 弱 类 型 语言 是 指 在 使 用 变量 时 不 用 指定 变量 的 类 型 ， 在 使 用 时 也 没有 类 型 检查 的 一 类 


编程 语言 


)， 所 以 在 使 用 变量 时 ,不 用 事先 指定 变量 类 型 ， 而 是 在 使 用 时 根据 上 下 文 由 系统 


解释 器 来 判断 变量 的 类 型 。 另外, PHP 也 不 像 其 他 编程 语言 要 先 定义 变量 才能 使 用 , 在 PHP 
中 ， 变 量 不 用 事先 定义 即 可 使 用 。 
1，PHP 的 变量 类 型 


PHP 


的 变量 类 型 有 以 下 几 种 : 整 型 变量 (integer)、 浮 点 型 变量 (double)、 字 符 型 变量 


(Cstring)、 数 组 型 变量 (array) 和 对 象 型 变量 (object)。 


回 


回 
回 


回 
回 


两 个 整 型 
【 例 


整 型 变量 在 32 位 操作 系统 中 的 有 效 范 围 是 -2147483648 一 +2147483647。 要 使 用 十 
六 进 制 整数 可 以 在 前 面 加 0x。 
浮 点 型 变量 在 32 位 操作 系统 中 的 有 效 范 围 是 1.7E-308 一 1.7E+308。 
字符 型 变量 不 同 于 其 他 编程 语言 ， 有 字符 与 字符 串 之 分 ， 在 PHP 中 ， 统 一 使 用 字 
符 型 变量 来 定义 字符 或 者 字符 串 。 
数组 型 变量 是 一 种 比较 特殊 的 变量 类 型 ， 将 在 2.1.5 节 进 行 详细 的 介绍 。 
对 象 变量 也 是 一 种 比较 特殊 的 变量 类 型 。 在 PHP 5 之 前 ，PHP 面向 对 象 编程 的 功 
能 还 不 是 很 强大 ，PHP 5 改变 了 这 种 状况 。 类 概念 的 引入 使 PHP 真正 成 为 一 种 面 
向 对 象 的 编程 语言 。 

-个 变量 的 方法 很 简单 , 在 该 变量 名 前 加 上 符号 $ 即 可 。 下 面 的 例子 就 分 别 定义 了 
变量 和 两 个 字符 型 变量 。 
2.9】 


<2php 


$a=0; 


/定义 一 个 整 型 变量 ， 赋 值 为 0 


$intl=1234: /定义 一 个 整 型 变量 ， 赋 值 为 1234 
$string="a": /定义 一 个 字符 型 变量 ， 赋 值 为 a 
$string 1="hello world! " /定义 一 个 字符 串 变 量 ， 赋 值 为 hello world! 


?> 


上 面 的 例子 能 够 发 现 ， 在 PHP 中 定义 一 个 变量 是 一 件 非常 简单 的 事情 。 


2. 变量 类 型 的 转换 


在 实 
改变 为 数 
中 可 通过 


际 使 用 PHP 的 过 程 中 ， 有 时 需要 对 变量 的 类 型 进行 强制 转换 ， 如 要 把 字符 型 变量 
值 型 变量 , 把 数值 型 变量 变 为 字符 型 变量 等 。 与 数据 类 型 的 强制 转换 一 样 , 在 PHP 
settype0 函 数 来 设置 一 个 变量 的 类 型 。 其 使 用 方式 如 下 所 示 : 


settype(mixed var,string type) 


其 作 


用 是 将 变量 var 的 类 型 设置 成 type。 type 的 可 能 值 ( 即 能 够 转变 的 类 型 ) 为 boolean 


\ /4 (或 为 bool)、integer (或 为 mt)、float、string、array、object、NULL。 
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如 果 类 型 转换 成 功 则 返回 TRUE， 失 败 则 返回 FALSE。 
下 面 通 过 一 个 实例 来 说 明 settype0 函 数 是 如 何 实现 变量 类 型 设置 的 。 
【 例 2.10】 


<html> 

<head> 

<title> 变量 类 型 转换 </title> 

</head> 

<body> 

<?php 

$foo="5abe"; /定义 一 个 字符 串 变 量 
Sbcd=true; // 定 义 一 个 逻辑 型 变量 

echo $foo; // 输 出 变量 $foo 

echo "<p>"; // 输 出 HTML 回 车 换行 

echo $bced; // 输 出 变量 $bcd 

echo "<p>"; 

settype($foo,"int"):; // 重 新 设置 $foo 的 类 型 为 整 型 
settype($bcd,"string"); /重新 设置 $bcd 的 类 型 为 字符 型 
echo $foo; // 重 新 输出 $foo 

echo "<p>"; 

echo $bed; // 重 新 输出 $bcd 


运行 结果 如 图 2.8 所 示 。 


OO， ne [GDIC 
富 收藏 天 。 条 去 县 类 型 牧 的 


5abc 


图 2.8 ”变量 类 型 转换 结果 

在 使 用 settypeO 函 数 前 ，$foo 变量 值 为 字符 串 、$bcd 变量 值 为 逻辑 真 值 ， 所 以 输出 结 
果 为 5abc、1; 在 使 用 settype0 函 数 后 ，$foo 变量 值 改 变 为 整 型 数 、$bcd 变量 值 改变 为 字 
符 串 ， 所 以 输出 结果 为 5、1。 
3. 可 变 变量 
有 时 使 用 可 变 变 量 名 是 很 方便 的 。 就 是 说 ， 一 个 变量 的 名 称 可 以 动态 地 设置 和 使 用 
一 个 普通 的 变量 通过 声明 来 设置 ， 例 如 : 

<?phbp 


$a="hello": 


?> ~ 
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一 个 可 变 变 量 获取 了 一 个 普通 变量 的 值 作为 其 变量 名 。 在 上 面 的 示例 代码 中 ，hello 使 
用 了 两 个 $ 符 号 以 后 ， 就 可 以 作为 一 个 可 变 变 量 了 。 例 如 : 
<2php 


$$a="world": 
和 


这 时 ， 两 个 变量 都 被 定义 : $a 的 内 容 是 hello，S$hello 的 内 容 是 world。 因 此 ， 可 以 表 
述 为 ; 
<2php 


echo"$a ${$a}"; 


以 下 写法 更 准确 并 且 会 输出 同样 的 结果 : 


<?php 

echo"$a$hello"; 

.> 

输出 结果 如 图 2.9 所 示 。 


变量 基 型 转换 EET Internet 
OO-E localhost/: [sz |X| a 
突 收 京 天 荐 到 县 类 型 竺 执 


helloworld 


图 2.9 可 变 变 量 输 出 结果 


要 将 可 变 变 量 用 于 数组 ， 必 须 解 决 一 个 问题 ， 这 就 是 当 写 下 $$a[1] 时 , 解析 器 需要 知 
道 是 想 要 $a[1] 作为 一 个 变量 ， 还 是 想 要 $$a 作为 一 个 变量 并 取出 该 变量 中 索引 为 []] 
的 值 。 解 决 此 问题 的 语法 是 ， 对 第 一 种 情况 用 ${$a[1]}， 对 第 二 种 情况 用 ${$a}[1]。 


[注意 
| 可 变 变量 不 能 用 于 PHP 的 超 全 局 变量 数组 ， 即 不 能 使 用 ${$_GET}。 


4. 变量 范围 

和 其 他 编程 语言 一 样 ，PHP 中 的 变量 也 有 全 局 变量 与 局 部 变量 之 分 。 所 谓 全 局 变量 指 
在 程序 运行 期 间 都 能 使 用 的 变量 ， 而 局 部 变量 只 在 子 函数 或 过 程 中 有 效 。 在 PHP 程序 执行 
时 ， 系 统 会 在 内 存 中 保留 一 块 全 局 变量 的 区 域 。 实 际 运 用 时 ， 可 以 通过 $SGLOBALS[" 变 量 
名 称 " ] 的 数组 调用 方法 将 需要 的 全 局 变量 调 出 。 不 过 需要 注意 的 是 ，PHP 的 变量 有 大 小 写 
之 分 ， 如 果 搞 错 了 大 小 写 是 不 能 调 出 来 的 。 

$GLOBALS 数组 是 PHP 程序 中 比较 特殊 的 变量 ， 不 必 声 明 ， 系 统 会 自动 匹配 相关 的 


变量 在 里 面 。 在 函数 中 ， 也 不 必 管 SGLOBALS 数组 是 否 已 经 被 声明 ， 就 可 以 直接 使 用 。 
/ 
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和 $GLOBALS 变量 类 似 的 还 有 $php_errormsg 字符 串 变 量 。 若 PHP 的 配置 文件 php.ini 
中 的 track _errors 选项 值 为 True， 使 用 全 局 变量 Sphp_errormsg 可 以 看 到 错误 的 信息 。 

在 PHP 中 ， 全 局 变量 的 有 效 范围 只 限于 主 程序 中 ， 不 会 影响 到 函数 中 同名 的 变量 ， 也 
就 是 全 局 变量 与 局 部 变量 互 不 干扰 。 若 要 全 局 变量 也 能 在 子 函数 中 使 用 ， 就 要 用 到 
$GLOBALS 数组 或 是 使 用 globals 宣告 。 


2.1.4 PHP 中 的 预定 义 变 量 


PHP 在 系统 中 内 置 了 大 量 与 系统 、 正 在 运行 的 PHP 文件 、HTTP 等 相关 的 变量 ， 如 
表 2.3 所 示 。 了 解 和 使 用 这 些 内 置 变量 对 提高 编程 效率 有 很 大 帮助 。 下 面 将 介绍 一 些 常 用 
的 PHP 预定 义 变量 ， 更 多 的 变量 请 参考 Phpinfo0 函 数 所 列 出 的 内 容 。 


表 2.3 PHP 预定 义 变量 


名 称 作 用 
$_SERVERI[PHP SELF] 当前 正在 执行 的 文件 名 。 返 回 值 与 document.root 相关 


$_SERVER[REQUEST_METHOD] | 访问 页 面 时 的 请 求 方法 ， 如 GET 

$_ SERVER[DOCUMENT ROOT] | 当前 运行 脚本 所 在 的 文档 根 目 录 。 在 APACHE 配置 文件 中 定义 
链接 到 当前 页 面 的 前 一 页 的 URL 地 址 。 不 是 所 有 的 用 户 代 理 ( 浏 览 

$_SERVER[HTTP REFERER] 器 ) 都 会 设置 该 变量 ， 而 且 有 的 还 可 以 手工 修改 HTTP_REFERER。 
因此 ， 该 变量 不 总 是 正确 真实 的 


$_ SERVER[REMOTE ADDR] 正在 浏览 当前 页 面 用 户 的 卫 地 址 

$_ COOKIE 通过 HTTP cookies 传递 的 变量 组 成 的 数组 ， 是 自动 全 局 变量 

$_GET 通过 HTTP GET 方法 传递 的 变量 组 成 的 数组 ， 是 自动 全 局 变量 

$ POST 通过 HTTP POST 方法 传递 的 变量 组 成 的 数组 ， 是 自动 全 局 变量 

Se 通过 HTTP POST 方法 传递 的 已 上 传 文件 项 目 组 成 的 数组 , 是 自动 全 
局 变量 

$_REQUEST 此 关联 数组 包含 $ GET、$_ POST 和 $_COOKIE 中 的 全 部 内 容 

$_SESSION 包含 当前 脚本 中 已 经 注册 的 session 变量 的 数组 

$GLOBALS 由 所 有 已 定义 全 局 变量 组 成 的 数组 。 变 量 名 是 该 数组 的 索引 


2.1.5 PHP 中 的 数组 型 变量 


数组 型 变量 是 一 组 具有 相同 类 型 和 名 称 的 变量 的 集合 。 数组 型 变量 是 一 种 独特 的 变量 ， 
PHP 中 的 数组 可 以 是 一 维 也 可 以 是 多 维 的 , 数组 内 元 素 的 类 型 可 以 是 数字 、 字符 甚 至 数组 。 
1. 数组 型 变量 的 初始 化 
在 PHP 中 初始 化 数组 一 般 有 两 种 方法 ， 一 种 是 同时 给 数组 中 所 有 元 素 赋值 ， 另 一 种 是 
单独 给 数组 每 个 元 素 赋值 。 下 面 通 过 实例 来 具体 了 解 这 两 种 方法 。 

【 例 2.11】 

方法 一 : 同时 给 数组 元 素 赋值 


\ 


‘1 
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<html> 

<head> 

<title> 同 时 给 数组 所 有 元 素 赋值 例子 </title> 
</head> 

<body> 

<2?php 

$string=array( 

"string1", 

"string2", 

"string3", 

"string4", 

"string5", 

入 /定义 一 个 数组 同时 给 数组 所 有 元 素 赋值 
for($i=0;$i<count($string);$i++) /循环 读 取 数组 内 容 
{ 

echo $string[$i]; // 显 示 数 组 元 素 
echo"<br>"; /输出 HTML 换行 符 
</body> 

</html> 

方法 二 : 单独 给 数组 每 个 元 素 赋值 

<html> 

<head> 

<title> 单 独 给 数组 元 素 赋值 例子 </title> 

</head> 

<body> 

<?php 

$string[0]="string1"; // 定 义 数组 ， 给 数组 每 个 元 素 单独 赋值 
S$string[1]="string2"; 

$string[2]="string3"; 

S$string[3]="string4"; 

$string[4]="string5"; 


for($i=0:$i<count($string):$i++) // 循 环 读 取 数 组 内 容 
{ 

echo $string[$i]: // 显 示 数 组 元 素 
echo "<br>"; // 输 出 HTML 换行 符 
’} 

?> 

</body> 

</html> 


两 种 方法 的 运行 结果 如 图 2.10 所 示 。 
从 图 中 可 以 看 到 ， 除 表 头 不 一 样 外 ， 输 出 的 结果 是 相同 的 ， 即 两 种 给 数组 元 素 赋值 的 
方法 所 实现 的 结果 是 一 样 的 。 


\y/ 
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leaheswz 国 | 区][x] 仿 


SO- 


次 收 诚 天 项 针 ] 冶 数 姐 所 有 元 来 赋 什 子 


GO Bu 


斌 收 训 天 。 | 大 有 和 和 结 数 查 元素 赋值 例子 


stringl stringl 

string2 string2 

string3 string3 

String4 string4 

string5 string5 

(a) 方法 一 结果 (b) 方法 二 结果 

pea 图 2.10 数组 赋值 图 示 
1 注意 


在 单独 赋值 时 一 定 要 注意 数组 元 素 的 编号 ， 数 组 的 第 一 个 元 素 的 编号 是 string[0]， 依 
次 向 后 排 ， 包 括 多 维 数组 中 也 是 一 样 的 ， 在 赋值 与 输出 数组 元 素 时 一 定 不 要 弄 错 。 


2. 动态 增加 数组 元 素 


一 个 数组 在 定义 后 ， 其 元 素 个 数 并 不 是 一 成 不 变 的 ， 在 程序 运行 中 可 以 动态 地 为 数组 
增加 元 素 。 要 给 一 个 数组 动态 增加 元 素 ， 所 要 做 的 只 是 给 数组 新 的 元 素 赋值 。 下 面 仍然 通 
过 实例 来 说 明 这 一 问题 。 

【 例 2.12】 


<html> 

<head> 

<title> 动 态 增加 数组 元 素 </title> 
</head> 

<body> 

<2php 

$string=array( 

"string1", 

"string2", 

"string3", 

"string4", 

"string5", 

六 /定义 一 个 数组 
echo "数组 的 第 三 个 元 素 为 :"; 

echo $string[2]; // 获 取 数 组 元 素 
echo "<br>"; 


echo "数组 的 第 五 个 元 素 为 :"; 


echo $string[4]; 
echo "<br>"; 
$string[5]="string6"; /为 数组 动态 增加 元 素 


S$string[6]="string7"; 

echo "下 面 是 新 增加 的 数组 元 素 : <br>"; 

echo "数组 的 第 六 个 元 素 为 :"; 

echo $string[5]: // 获 取 新 增加 的 元 素 
echo "<br>"; 


echo "数组 的 第 七 个 元 素 为 :"; N\ YL1/ 
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echo $string[6]; 
?> 
</body> 
</html> 


执行 结果 如 图 2.11 所 示 。 


数组 的 第 二 个 元 素 为 ; string7 


图 2.11 动态 增加 数组 元 素 执行 结果 
3. 创建 多 维 数组 


一 维 数组 的 格式 是 Armray[]， 二 维 数组 的 格式 是 Array[]]， 多 维 数组 的 格式 是 
Array[][.…[]。 和 一 维 数 组 一 样 ， 给 多 维 数组 赋值 也 有 两 种 方法 。 下 面 分 别 通过 实例 来 具体 
说 明 。 

先 来 了 解 一 下 同时 给 多 维 数组 所 有 元 素 赋值 。 例 2.13 要 完成 的 功能 是 在 定义 数组 的 同 
时 ， 给 数组 所 有 元 素 赋值 。 

【 例 2.13】 


<html> 

<head> 

<title> 同 时 给 多 维 数组 所 有 元 素 赋值 </title> 
</head> 

<body> 

<2php 

S$string=array( 

0=>array(0,1,2), 
1=>amay("stringl","string2","string3","string4")， 
2=>array(" 你 好 "," 我 好 "," 大 家 好 ") 
六 /创建 二 维 数组 ， 数 组 元 素 也 是 数组 
for($i=0:;$i<count($string);$i++) 

{ 

for($j=0:$j<count($string[$i]):$j++) 


长 
echo $string[$il[$j]: 


echo",": 


echo "<br>"; 


} 


?> 
</body> 
</html> 
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简单 地 讲 ， 多 维 数组 的 数组 元 素 也 是 由 数组 来 组 成 的 ， 上 面 的 例子 是 一 个 二 维 数组 ， 
如 果 该 二 维 数组 中 的 某 一 个 元 素 为 数组 ， 那 么 就 变 成 了 三 维 数组 。 由 此 便 是 多 维 数组 的 组 
成 。 例 2.13 的 运行 结果 如 图 2.12 所 示 。 


同时 给 多 维 数组 所 有 元 素 峰 值 -~ Windows Int-- 


GO-E locanost: ty x| | 访 
寅 收 妆 天 。 | 乱 风 jj 结 乡 推 区 组 所 有 元 素 限 全 


0, 1, 2, 
stringl, string2, string3, stringd, 


你 好 ， 我 好 ， 大 家 好 ， 


图 2.12 多 维 数组 示例 

例 2.13 是 同时 给 多 维 数组 元 素 赋值 的 示例 ， 多 维 数组 也 可 以 与 一 维 数组 一 样 ， 单 独 给 
数组 元 素 赋值 ， 也 就 是 array[il[j]="string"， 这 里 不 再 歼 述 。 

练习 
. PHP 中 的 数据 类 型 有 哪些 ? 
.如 何 定义 与 使 用 常量 ? 
PHP 中 有 哪些 变量 类 型 ? 
在 使 用 PHP 变量 时 应 注意 哪些 内 容 ? 
如 何 给 数组 元 素 赋值 ? 
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任务 2 认识 PHP 中 这 工 蔡 及 底 程 镁 制 语 昌 


任务 描述 


流程 控制 在 任何 编程 语言 中 的 基础 性 和 重要 性 都 是 毋庸 置疑 的 ， 本 任务 中 所 讲述 的 
PHP 中 的 流程 控制 同样 是 PHP 编程 学 习 的 重点 内 容 ，PHP 的 语法 继承 于 C 语言 的 语法 ， 
在 流程 控制 方面 也 非常 类 似 。 本 任务 将 介绍 PHP 中 的 判断 与 循环 语句 ， 包 括 站 ..else 判断 、 
switch...case 多 重 判 断 、while 循环 、do...while 循环 、for 循环 等 内 容 。 通 过 对 本 任务 的 学 
习 ， 读 者 可 掌握 PHP 流程 控制 知识 ， 为 编写 大 型 程序 葛 定 坚实 的 基础 。 


知识 汇总 
2.2.1 运算 符 


运算 符 与 表达 式 是 PHP 中 十 分 重要 的 概念 。 在 PHP 编程 中 ， 表 达 式 是 PHP 程序 最 
要 的 基石 ， 而 运算 符 又 是 构成 表达 式 的 基础 。 可 以 说 ， 任 何 复杂 的 PHP 程序 都 是 由 最 基本 
的 运算 符 和 表达 式 组 成 的 。 熟 练 运用 PHP 中 的 运算 符 与 表达 式 ， 是 进行 PHP 编程 的 基本 
功 。 在 本 节 中 将 进行 运算 符 的 学 习 。 
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1. PHP 中 的 运算 符 
PHP 中 的 运算 符 可 分 为 算术 运算 符 、 递 增 递 减 运算 符 、 比 较 运 算 符 、 逻 辑 运算 符 、 位 
运算 符 和 其 他 运算 符 6 种 。 
(1) 算术 运算 符 : 即 加 、 减 、 乘 、 除 以 及 取 余 〈 又 称 取 模 ) 5 种 运算 ， 如 表 2.4 所 示 。 
表 2.4 算术 运算 符 


运 算 符 结 果 
$at$b $a 与 $b 的 和 
$a-$b $a 与 $b 的 差 
$a*$b $a 与 $b 的 积 
$a/$b $a 除 以 $b 的 商 
$ao%os$b $a 除 以 $b 的 余数 


简单 地 讲 ， 算 术 运 算 符 就 是 四 则 运算 的 表现 ， 是 最 简单 的 运算 符 。 
(2) 递增 递减 运算 符 : 又 称 加 1 减 1 运算 符 ， 如 表 2.5 所 示 。 


表 2.5 “递增 递减 运算 符 
名 称 


$a 的 值 先进 行 操作 ， 后 减 1 


【 例 2.14】 


<html> 
<head> 
<title> 递 增 递减 运算 符 </title> 
</head> 
<body> 
<?php 
$a=10; 
$b=3; 
echo $a%$b; // 输 出 余 值 1 
echo "<br>"; 
echo $a++; // 先 输出 $a 的 值 ， 然 后 加 1 并 重新 赋值 给 $a 
echo "<br>"; 
echo ++$a; // 先 加 1 赋值 给 $a， 然 后 输出 $a 
echo "<br>"; 
echo $b--; // 先 输出 $b 的 值 ， 然 后 减 1 并 重新 赋值 给 $b 
echo "<br>"; 
echo --$b: // 先 减 1 赋值 给 $b， 然 后 输出 $b 
?> 
</body> 
/ </html> 
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图 2.13 递增 递减 运算 示例 


首先 赋 给 $a 的 值 为 0，$a++ 则 是 先 输出 $a 的 值 ， 然 后 加 1 并 重新 赋值 给 $a， 故 第 二 
行 的 输出 结果 为 0， 输 出 结果 之 后 $a 的 值 变 为 11， 下 面 ++$a 是 先 加 1 再 输出 ， 所 以 输出 
结果 为 12， 下 面 的 递减 运算 也 是 同样 的 道理 。 

(3) 比较 运算 符 : 一 个 常用 的 表达 式 类 型 是 比较 表达 式 ， 这 些 表 达 式 的 值 为 FALSE 
或 TRUE， 如 表 2.6 所 示 。 


表 2.6 ”比较 运算 符 


运 算 符 名 称 结 果 

$a—$b 等 于 TRUE， 如 果 $a 等 于 $b 

$a=—=$b > 等 于 TRUE， 如 果 $a 等 于 $b， 并 且 它 们 的 类 型 也 相同 
$a!l=$b TRUE， 如 果 $a 不 等 于 $b 

$a>$b TRUE， 如 果 $a 不 等 于 $b 

$a!l—$b TRUE， 如 果 $a 不 等 于 $b， 或 者 它们 的 类 型 不 同 
$a<$b TRUE， 如 果 $a 严格 小 于 $b 

$a>$b TRUE， 如 果 $a 严格 大 于 $b 

$a<=$b TRUE， 如 果 $a 小 于 或 者 等 于 $b 

$a>=$b TRUE， 如 果 $a 大 于 或 者 等 于 $b 


(4) 逻辑 运算 符 : PHP 中 的 逻辑 运算 符 有 与 、 或 、 异 或 、 非 4 种 。 其 中 的 逻辑 与 和 由 
辑 或 有 两 种 表现 形式 ， 如 表 2.7 所 示 。 


表 2.7 逻辑 运算 符 


名 称 
$a and $b ， 如 果 $a 与 $b 都 为 TRUE 
$a or $b Or (逻辑 或 ) TRUE， 如 果 $a 或 $b 任 一 为 TRUE 
$a xor $b | Xor (逻辑 异 或 ) TRUE， 如 果 $a 或 $b 任 一 为 TRUE， 但 不 同时 是 
! $a | Not (逻辑 非 ) TRUE， 如 果 $a 不 为 TRUE 
Sa&& $b | And (逻辑 与 ) TRUE， 如 果 $a 与 Sb 都 为 TRUE 
$all $b Or (逻辑 或 ) TRUE， 如 果 $a 与 $b 任 一 为 TRUE 


下 面 通过 实例 来 说 明 风 辑 运算 符 的 运用 。 由 于 && 等 价 于 and，|| 等 价 于 or， 所 以 就 不 、 7 
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再 单独 说 明了 。 
【 例 2.15】 


<html> 

<head> 

<tile> 逻 辑 运 算 符 使 用 实例 </title> 

<body> 

<2php 

$a=TRUE; /定义 逻辑 变量 真 
$b=FALSE:; /定义 逻辑 变量 假 
这 $a and $b) echo "这 里 为 假 1! "; // 求 与 

echo "<br>"; 

这 $a or $b) echo "这 里 为 真 1! "; // 求 或 

echo "<br>"; 

这 $a xor $b) echo "这 里 为 真 21 "; // 求 异 或 

echo "<br>"; 

这 !$a) echo "这 里 为 假 21"; // 求 非 

?> 

</body> 

</html> 


在 PHP 执行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 2.14 所 示 。 从 图 中 可 以 发 现 ， 以 上 
代码 中 只 有 两 句 echo 语句 成 功 运 行 。 下 面 分 析 一 下 以 上 程序 4 个 站 语句 的 运行 过 程 : 

回 第 1 个 判断 对 一 真一 假 两 项 求 与 。 因 两 者 不 同时 为 真 ， 所 以 返回 “ 假 ”% 

回 第 2 个 判断 对 一 真一 假 两 项 求 或 。 因 二 者 有 一 个 为 真 ， 所 以 返回 “ 真 ” 

回 第 3 个 判断 对 一 真一 假 两 项 求 异 或 。 因 两 者 状态 不 同 ， 所 以 返回 “ 真 ”。 

回 第 4 个 判断 对 一 个 真 值 求 非 ， 则 返回 “ 假 ” 

把 以 上 代码 做 如 下 改动 : 把 这 $a and $b) 改 为 这 !($a and $b))， 把 这 !$a) 改 为 f(!1$b)。 然 
后 运行 代码 ， 结 果 如 图 2.15 所 示 。 
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这 里 为 真 11 这 多 11 

人 2 

图 2.14 逻辑 运算 符 使 用 实例 执行 结果 1 图 2.15 逻辑 运算 符 使 用 实例 执行 结果 2 


(5) 位 运算 符 : 位 运算 符 允 许 对 整 型 数 中 指定 的 位 进行 置 位 。 如 果 左 右 参 数 都 是 字符 
串 ， 则 位 运算 符 将 操作 字符 的 ASCII 值 ， 如 表 2.8 所 示 。 


表 2.8 位 运算 符 


表 达 式 名 称 结 
$a&$b | And ( 按 位 与 ) 将 在 $a 和 S$b 中 都 为 1 的 位 设 为 1 
\y $a | $b Or ( 按 位 或 ) 将 在 $a 或 者 gb 中 为 1 的 位 设 为 1 
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Not ( 按 位 非 ? 
$a<<$b | Shiftleft ( 左 移 ) 
$a>>$b Shiftright ( 右 移 ) 


将 在 $a 和 $b 中 不 同 的 位 设 为 1 
将 $a 中 为 0 的 位 设 为 1， 反 之 亦 然 
将 $a 中 的 位 向 左 移动 $b 次 《每 一 次 移动 都 表示 “ 乘 以 2”) 
将 $a 中 的 位 向 右 移动 $b 次 《每 一 次 移动 都 表示 “ 除 以 2”) 


(6) 其 他 运算 符 : 上 面 介绍 的 运算 符 是 比较 常用 的 运算 符 ， 另外 还 有 几 种 运算 符 在 这 
里 简单 地 说 明 一 下 。 

回 字符 串 运算 符 : 有 两 个 字符 串 运算 符 。 一 个 是 连接 运算 符 (.)， 它 返回 其 左右 参 
数 连接 后 的 字符 串 ;， 另 一 个 是 连接 赋值 运算 符 (=)， 它 将 右边 参数 附加 到 左边 的 
参数 后 。 

回 ”错误 抑制 操作 符 : 在 最 常见 的 数据 库 连 接 与 文件 创建 操作 或 出 现 除 0 等 异常 时 ， 
可 以 用 @ 符 号 来 抑制 函数 错误 信息 输出 到 浏览 器 端 ， 如 $a=@(5/0)。 

回 ”数组 运算 符 : PHP 仅 有 的 一 个 数组 运算 符 是 + 运算 符 。 它 把 右边 的 数组 附加 到 
左边 的 数组 后 ， 但 是 重复 的 键 值 不 会 被 攻 盖 。 

加 三 目 运 算 符 ， 其 运行 机 制 为 (exprl)?(expr2):(expr3)， 其 中 的 exprl 、expr2 及 expr3 
均 为 表达 式 。 当 表达 式 exprl 为 真 时 ， 则 执行 后 边 的 expr2， 反 之 则 执行 expr3 。 
从 分 析 中 不 难看 出 ， 三 目 运算 符 实际 上 是 让 .else 的 简化 版 。 

回 ”外 部 命令 执行 : 使 用 "来 运行 外 部 系统 命令 。 注 意 不 是 单 引 号 ， 是 键盘 上 esc 下 
面 那个 按键 ， 如 例 2.16 所 示 。 

【 例 2.16】 

<2php 

S$out=" dirc 

print I($out): 

?> /不 建议 使 用 


【 例 2.17】 


<?php 

$a="hello"; 

$a.=" world! ": // 等 同 于 $a=$a." world!"; 
echo $a; // 输 出 : hello world! 
echo "<br>"; 
$m=3; 

$m += 5; /等 同 于 $m=$m+5: 
echo $m:; // 输 出 8 

echo "<br>"; 
$c=($b=4)+5; 
echo $c: // 输 出 : 9 
?> 
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运行 结果 如 图 2.16 所 示 。 


国 v* 同 localhost/: 加 | 坟 |x| 二 
写 收 戌 天 。 古 http://localhost/2.15. php 


hello world! 
8 


9 


图 2.16 其 他 运算 符 实例 执行 结果 
2. 运算 符 优先 级 
运算 符 优先 级 指定 表达 式 的 运算 顺序 。 例 如 ， 表 达 式 1+2*3 的 结果 是 7 而 不 是 9， 是 
因为 乘 号 〈*#) 的 优先 级 比 加 号 〈+) 高 。 必 要 时 可 以 用 括号 来 强制 改变 优先 级 。 例 如 ，(1+2) 
*3 的 值 为 9。 
表 2.9 从 低 到 高 列 出 了 运算 符 的 优先 级 。 


表 2.9 运算 符 优先 级 


结合 方向 运 算 符 附加 信息 
左 or 逻辑 运算 符 
左 Xor 逻辑 运算 符 
左 and 逻辑 运算 符 
右 ==、+=、-=、*=、/=、.=、%=、&=、|F=、^、~=、<<=、>>=| 赋值 运算 符 
左 9: 三 日 运算 符 
A 逻辑 运算 符 
左 && 逻辑 运算 符 
左 位 运算 符 
左 由 位 运算 符 
左 & 位 运算 符 和 引用 
无 一 、 上 二 一、 一 比较 运算 符 
无 <、 <、 >, > 比较 运算 符 
左 < > 位 运算 符 
左 十 -、. 算术 运算 符 和 字符 串 运算 符 
左 a 算术 运算 符 
右 !、~、++、--、(inb(floab(string)(array)(objecbD@ 类 型 
右 [ arrayO 
无 new, New 


结合 方向 为 左 表 示 表 达 式 从 左 向 右 求 值 , 方向 为 右 则 相反 。 从 表 2.9 中 可 以 发 现 , PHP 
中 的 运算 符 有 严格 的 运算 优先 级 。 只 有 搞 清 楚 了 它们 的 优先 级 ， 才 能 正确 得 出 由 运算 符 构 
成 的 表达 式 的 值 。 下 面 通 过 实例 来 说 明 PHP 中 运算 符 的 优先 级 在 实际 中 的 运用 。 
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【 例 2.18】 


<html> 

<head> 

<title> 运 算 符 优先 级 示例 </tile> 

</head> 

<body> 

<?php 

$a=3*4+5%2; // 语 句 1 
echo $a,"<br>"; 

$a=true?0:true?1:2; // 语 句 2 
echo $a."<br>"; 

$a=1; 

$b=2; 

$a-=$b+=3*$b+$a; // 语 句 3 
echo $a.",".$b."<br>"; 

?> 

</body> 

</html> 


运行 结果 如 图 2.17 所 示 。 


运算 符 优 先 级 示例 Windows Internet 
GO， Gr ne 国 S | 
宣 收 蕊 天 。 狗 运 算 罕 忧 先 刀 示例 
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2 
-8,9 


图 2.17 运算 符 优先 级 示例 

不 管 多 么 复杂 的 表达 式 ， 只 要 按 优先 级 把 它 分 解 为 简单 的 表达 式 ， 就 可 以 分 析 其 结果 
了 。 下 面 对 例 2.17 中 的 3 个 语句 逐一 分 析 。 

第 1 个 语句 相对 简单 ， 只 需 分 解 为 (3*4)+(5%2) 即 可 。3*4 等 于 12, 5 除 以 2 余数 为 1， 
所 以 就 是 12+1， 等 于 13。 

第 2 个 语句 稍微 复杂 ， 可 以 分 为 两 个 三 目 运 算 符 : (tue?0:tue)?1:2=2。 第 1 个 三 目 运 
算 符 执行 后 ， 前 面 括号 内 容 为 0， 而 0 相当 于 FALSE， 所 以 执行 第 2 个 三 目 运算 符 第 2 个 
表达 式 ， 所 以 就 有 $a 等 于 2。 

第 3 个 语句 比较 复杂 。$a-=$b+=3*+$b+$a 分 解 后 等 价 于 这 样 一 组 表达 式 ， $b*3 等 于 6， 
6+$a 等 于 7，$b+7 等 于 9，$b=9，$a-9 等 于 -8，$a=-8。 通 过 分 解 可 以 发 现 ， 输 出 的 结果 为 
$a=-8、$b=9。 

通过 上 面 的 例子 发 现 ， 只 有 掌握 了 PHP 运算 符 的 优先 级 ， 才 能 把 复杂 的 表达 式 转化 为 
简单 的 表达 式 ， 从 而 得 出 表达 式 的 正确 结果 。 


2.2.2 表达 式 


表达 式 是 PHP 最 重要 的 基石 。 在 PHP 中 , 几乎 用 户 所 写 的 任何 东西 都 是 一 个 表达 式 。、 | / 
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简单 但 却 最 精确 地 定义 一 个 表达 式 的 方式 就 是 anything that has a value。 

最 基本 的 表达 式 形式 是 常量 和 变量 。 当 输入 $a = 5 时 ， 即 将 值 5 分 配给 变量 Sa。 很 明 
显 ，5 的 值 为 5。 换 名 话说，5 是 一 个 值 为 5 的 表达 式 〈 既 然 如 此 ，5 是 一 个 整 型 常量 )。 赋 
值 之 后 ， 你 所 盼望 的 情况 是 $a 的 值 为 5， 因而 如 果 写 下 $b = $a， 期 望 的 是 它 犹 如 $b = 5 一 
样 。 换 句 话 说，$a 也 是 一 个 值 为 5 的 表达 式 。 如 果 一 切 运行 正确 ， 那 这 正 是 将 要 发 生 的 正 
确 结果 。 函 数 是 稍微 复杂 一 点 的 表达 式 形式 。 例 如 下 面 的 函数 : 

<?php 

function foo0) 


retum 5 


?> 
那么 输出 $a=foo0 就 相当 于 写 下 $a=5。 函 数 也 是 表达 式 , 表达 式 的 值 即 为 它们 的 返回 值 。 
1. 表达 式 中 变量 的 可 能 值 
表达 式 赋 值 给 一 个 变量 ， 其 中 的 值 可 能 为 PHP 支持 的 4 种 标量 值 (标量 值 不 能 拆 分 为 
更 小 的 单元 ， 和 数组 、 对 象 不 同 ) 类 型 : 整 型 值 (integer) 、 浮 点 数值 (float) 、 字 符 串 值 
(string) 和 布尔 值 (boolean) ， 还 包括 两 种 复合 类 型 〈 数 组 和 对 象 ) 。 所 以 表达 式 的 值 可 
能 为 PHP 中 所 有 的 变量 类 型 。 
2. 赋值 表达 式 的 值 
一 个 赋值 表达 式 通 常 涉及 到 两 个 值 ， 如 $a=3。 这 样 一 个 表达 式 涉 及 到 整 型 常量 3 的 值 
以 及 变量 $a 的 值 ， 它 也 被 更 新 为 3。 还 有 一 个 赋值 语句 本 身 的 值 。 赋 值 语句 本 身 求 值 为 被 
赋 的 值 即 3。 因而 ，$b=($a=3) 和 $a=3:$b=3:; 是 一 样 的 。 因 为 赋值 操作 的 顺序 是 由 右 到 左 的 
也 可 以 写作 $b=$a=3。 
通过 以 上 介绍 知道 ， 赋 值 表 达 式 牵涉 3 个 值 : 赋值 变量 值 、 被 赋 的 常量 值 及 表达 式 自 
身 的 值 。 
3. 递增 ( 减 ) 表达 式 
递增 ( 减 ) 表达 式 是 一 种 比较 特殊 的 表达 式 ， 这 类 表达 式 是 一 个 很 好 的 面向 表达 式 的 
例子 。 该 类 表达 式 有 前 、 后 递增 和 递减 。 本 质 上 来 讲 ， 前 递增 和 后 递增 均 增 加 了 变量 的 值 ， 
并 且 对 于 变量 的 影响 是 相同 的 ， 不 同 的 是 递增 表达 式 的 值 。 前 递增 写作 ++$variable， 求 增 
加 后 的 值 ， 后 递增 写作 $variablet++， 求 变量 未 递增 之 前 的 原始 值 。 
下 面 举例 说 明 这 个 问题 。 
【 例 2.19】 
<html> 
<head> 
<title></title> 
<body> 
VY Tphp 
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$a=3; 
echo "\$a=3&nbsp;&nbsp;"; 


echo "++\$a 为 : "; 

echo ++$a; //$a 前 递增 

echo "<p>": 

$a=3; //$a 重新 赋值 为 3 


echo "\$a=3&nbsp;&nbsp;"; 

echo \$at+ 为 : "; 

echo $a++; //$a 后 递增 
?> 

</body> 

</html> 


在 PHP 环境 下 执行 代码 ， 其 执行 结果 如 图 2.18 所 示 。 
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$a=3 ++a 为 4 
$a=3 $att 为 ， 3 
图 2.18 ”前 递增 表达 式 与 后 递增 表达 式 的 比较 
4. 比较 表达 式 
比较 表达 式 是 一 个 常用 到 的 表达 式 类 型 。 这些 表 达 式 求 值 FALSE 或 TRUE。PHP 支持 
> (大 于 ) 、>= (大 于 等 于 ) 、 二 (等于) 、!= (不 等 于 ) 、< (小 于 ) 、<= (小 于 等 于 ) 。 
PHP 还 支持 全 等 运算 符 ===〈( 值 和 类 型 均 相 同 ) 和 非 全 等 运算 符 !==〈 值 或 者 类 型 不 同 ) 。 
这 些 比较 表达 式 都 是 在 条 件 判断 语句 (如 站 语句 ) 中 最 常用 的 ， 通 常 被 当 作 条 件 判断 语句 
的 判断 条 件 。 
如 变量 $a 的 值 为 3， 变 量 $b 的 值 为 4， 则 表达 式 $a<$b 的 值 就 为 真 。 因 为 3 小 于 4。 反 
之 ，$a>$b 的 值 为 假 。 
5. 组 合 的 运算 赋值 表达 式 
通过 前 面 对 PHP 表达 式 的 介绍 知道 ， 如 果 想 要 为 变量 $a 加 1， 可 以 简单 地 写 $a++ 或 者 
++$a。 但 是 如 果 想 为 变量 增加 大 于 1 的 值 ， 如 3， 其 做 法 是 Sa=$a+3。$a+3 计算 Sa 加 上 3 
的 值 ， 并 且 得 到 的 值 重新 赋予 变量 ga， 于 是 $a 的 值 增加 了 3。 该 式 还 可 以 用 一 种 更 加 简短 
的 形式 $a+=3 表示 ， 意 思 是 取 变 量 $a 的 值 加 3， 得 到 的 结果 再 次 分 配给 变量 ga。 除 了 更 简 
略 和 清楚 外 ， 运 行 也 可 以 更 快 。$a+=3 的 值 如 同一 个 正常 赋值 操作 的 值 ， 是 赋值 后 的 值 。 
注意 它 不 是 3， 而 是 $a 的 值 加 上 3 后 的 值 (此 值 将 被 赋 给 Sa) 。 任 何 二 元 运算 符 都 可 以 用 
运算 赋值 模式 ， 例 如 $a-=5〈 从 变量 $a 的 值 中 减 去 S) ，$b*=7 (变量 $b 乘 以 7) 等 。 


2.2.3 ”流程 控制 语句 


无 论 在 何 种 编程 语言 中 ， 流 程控 制 都 是 非常 基础 且 重 要 的 内 容 。 由 于 PHP 大 部 分 都 继 、 | / 
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承 C 语言 的 特点 ， 因 
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此 在 流程 控制 方面 ，PHP 与 C 语言 类 似 。PHP 的 流程 不 像 ASP 那样 


可 以 使 用 goto 的 BASIC 语法 。 本 节 将 介绍 PHP 中 的 判断 与 循环 语句 ， 通 过 对 语句 的 学 习 
来 了 解 PHP 中 的 流程 控制 。 


1.， 判断 语句 


判断 语句 主要 是 通过 过 和 switch 两 种 条 件 语句 来 实现 的 。 


(1) 站 语句 。 


站 语句 是 流程 控制 中 判断 执行 的 一 种 ， 该 语句 执行 时 先 对 某 条 件 进行 判断 ， 然 后 根据 
判断 结果 做 出 相应 的 操作 。 寺 语句 可 以 分 为 3 种 :简单 的 寺 语 句 、if..else 语句 、\if...elseif...else 


语句 。 


@ 简单 的 让 语句 。 
站 判断 是 流程 控制 中 最 简单 的 一 种 。 它 只 判断 某 条 件 是 否 为 真 ， 如 果 为 真 ， 就 会 执行 


特定 的 语句 。 例 如 : 


这 expD) 
{ 


statement 


} 


如 果 要 执行 的 statement (语句) 多 于 一 句 ， 就 要 使 用 “{}” 把 它们 括 起 来 ， 表 示 一 个 
区 段 ， 如 果 要 执行 的 语句 只 有 一 句 ， 束 可 以 省 略 “{}” 标 记 。 下 面 通过 一 个 简单 的 实例 来 
说 明 站 语句 的 使 用 方法 。 


【 例 2.20】 


<html> 
<head> 


<title> 计 语句 示例 </title> 


</head> 

<body> 

<2php 

if ($score<60) 
echo "不 及 格 ! "; 
上 

</body> 

</html> 


// 如 果 分 数 不 到 60 


在 PHP 运行 环境 中 执行 以 上 语句 ,会 出 现 一 个 提示 和 执行 结果 ， 因 为 在 这 段 代码 中 没 
有 定义 变量 $score， 没 有 定义 的 变量 的 值 就 是 空 值 ， 作 为 数值 就 是 0。0 小 于 60， 符 合 站 
后 面 的 判断 语句 ， 所 以 得 到 的 结果 是 一 个 对 score 的 说 明 同 时 还 有 执行 结果 。 在 站 语句 之 


前 加 入 代码 : 


$score=59; 


再 执行 代码 得 到 的 就 是 正常 的 判断 输出 结果 ， 如 图 2.19 所 示 。 


| 


图 2.19 站 语 句 示例 


此 时 ， 变 量 $score 有 定义 的 值 并 且 符 合 后 面 站 语句 中 的 判断 条 件 ， 故 得 到 正确 的 执行 
结果 而 不 出 现 未 定义 变量 时 的 提示 。 但 如 果 定 义 的 变量 的 值 不 符合 站 判断 条 件 会 出 现 什么 
情况 呢 ? 例如 定义 $score=61， 执 行 结果 会 是 怎样 ? 经 过 执行 发 现 ， 当 $score>=60 时 ，echo 
输出 语句 是 不 会 执行 的 ， 即 代码 执行 后 什么 都 没有 显示 。 

@) Hf..else 语句 。 

简单 的 站 语句 只 在 判断 结果 为 真 的 情况 下 有 执行 操作 ， 这 在 大 多 数 情况 下 是 不 够 的 ， 
于 是 就 出 现 了 让..else 这 种 形式 的 判断 语句 。if..else 语句 不 仅 会 在 判断 结果 为 真 的 情况 下 执 
行 操作 ， 同 时 在 非 真 的 情况 下 也 会 执行 相应 的 操作 。 

下 面 对 例 2.21 中 代码 做 简单 的 修改 ， 来 说 明 应..else 语句 。 

【 例 2.21】 


<html> 

<head> 

<title>if...else 语句 示例 </title> 
</head> 

<body> 

<?php 

$score=61; 

if ($score<60) // 如 果 分 数 不 到 60 
echo "不 及 格 ! "; 

else 

echo "合格 "; 

> 

</body> 

</html> 


运行 结果 如 图 2.20 所 示 。 
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图 2.20 站..else 语句 示例 


@ if..elseif...else 语句 。 
虽然 让 ..else 语句 比 单纯 的 让 语句 多 了 一 重 判断 , 但 现实 情况 可 能 还 要 复杂 , 要 判断 的 


情况 会 超过 两 种 。 如 判断 学 生成 绩 ， 不 能 只 判断 及 格 或 不 及 格 ， 还 要 判断 优 、 良 、 中 、 差 。 1 
二 
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这 时 ， 不 管 是 使 用 简单 的 过 判断 ， 还 是 站 ..else 判断 都 不 能 实现 ， 要 用 到 站..elseif...else 的 
多 重 判断 。 
让 ..elseif...else 语句 的 使 用 方法 如 下 : 


这 expD 

{ 

statement 

} 
elseif(expr) 
{ 

statement 


} 


elseif(expr) 
' 

statement 

} 

else 

' 

statement 


} 


其 运行 原理 是 : 先进 行 一 次 判断 ， 如 果 值 为 真 ， 那 么 就 执行 语句 并 跳出 ， 否 则 就 继续 
J 判断 ， 一 直 持 续 到 值 为 真 ， 执 行 语句 并 跳出 ， 或 者 执行 完 所 有 的 判断 结束 。 

下 面 通过 实例 来 说 明 直 ..elseif...else 语句 的 使 用 。 

【 例 2.22】 


<html> 

<head> 

<title>if..elseif .else 语句 示例 </title> 

</head> 

<body> 

<2php 

$score=80; 

if ($score>90) // 如 果 分 数 高 于 90 
echo " 优 ! "; 

elseif($score>70) // 分 数 在 70 一 90 之 间 
echo " 良 ! "; 

elseif($score>60) // 分 数 在 60 一 70 之 间 
echo "中 ! "; 

else 

echo " 差 ! "; 

?> 

</body> 

</html> 


实例 中 定义 变量 score 的 值 为 80， 故 判断 语句 中 判断 到 $score>70 便 执行 输出 语句 并 跳 
\ /出 判断 ， 执 行 结果 如 图 2.21 所 示 。 
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图 2.21 让..elseif...else 语句 示例 


(2) switch...case 语句 。 
多 重 判 断 除 了 上 面 介绍 的 让 .elseif..else 语句 外 ， 还 有 一 种 就 是 switch...case 语句 。 相 
对 于 让 多 重 判 断 语 句 ，switch...case 更 加 简单 明了 。switch...case 语句 的 使 用 方法 如 下 : 


switch(expr){ 
case (exprl): 
statement1l; 
break: 
Case (expr2): 
statement2; 
break; 


default: 
statementN; 
break; 
} 


其 中 ，expr 通常 是 变量 名 称 ，case 后 的 exprN 通常 是 变量 的 值 ，statementN 为 符合 该 
值 时 执行 的 语句 ，default 为 除了 以 上 判断 情况 之 外 的 情况 ， 最 后 使 用 break 跳出 过 程 。 

下 面 通过 实例 来 实际 使 用 switch...case 语句 。 

【 例 2.23】 


<html> 
<head> 
<title>switch...case 语句 示例 </title> 
</head> 
<body> 
<?php 
switch(date("D")){ // 当 前 星期 作为 判断 条 件 
case"mon": // 星 期 一 的 情况 
echo" 星 期 一 "; 
break; 
case"tue": // 星 期 二 的 情况 
echo" 星 期 二 "; 
break: 
case"web": // 星 期 三 的 情况 
echo" 星 期 三 "; 
break:; 
case"thu": // 星 期 四 的 情况 
echo" 星 期 四 "; \ 71/ 
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ca 
break: 
case"fri": // 星 期 五 的 情况 
echo" 星 期 五 "; 
break: 
default: // 除 以 上 之 外 的 其 他 情况 
echo" 周 末 "; 
break: 
} 
?> 
</body> 
</html> 


在 PHP 运行 环境 下 执行 ， 就 会 返回 中 文 的 星期 。 运 行 结果 如 图 2.22 所 示 。 
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图 2.22 switch...case 语句 示例 图 示 


该 例如 果 用 站 语句 来 实现 就 会 比较 复杂 。 从 该 例 也 能 够 看 出 让 判断 与 switch...case 的 
不 同 。 在 使 用 switch...case 语句 时 ， 要 把 出 现 几率 大 的 情况 放 到 最 前 边 ， 这 样 可 以 提高 程 
序 执行 效率 。 因 为 在 进行 完 一 次 判断 后 ， 如 果 符 合 条 件 ， 执行 完 相 关 语 句 就 跳出 整个 过 程 。 
如 果 把 出 现 几率 大 的 情况 放 到 最 后 ， 就 得 执行 完 所 有 判断 ， 这 样 效率 就 低 得 多 。 

2. 循环 语句 

前 面 介 绍 了 PHP 流程 控制 中 的 判断 , 下 面 介绍 循环 。 循 环 也 是 很 重要 的 一 类 流程 控制 ， 
通过 循环 执行 某 些 特定 语句 要 比 多 次 执行 效率 高 。PHP 中 的 循环 可 分 为 while 循环 、 
do...while 循环 和 for 循环 三 大 类 。 

(1) 单纯 的 while 循环 。 

在 循环 控制 中 ， 有 一 种 最 简单 的 循环 模式 ， 即 先 判断 条 件 是 否 符合 特定 要 求 ， 如 果 符 
合 就 执行 特定 操作 ， 然 后 再 判断 ， 直 到 条 件 不 符合 则 退出 循环 。 但 如 果 一 开始 条 件 就 不 符 
合 要 求 , 则 一 次 也 不 执行 , 直接 跳出 循环 。 这 种 循环 模式 在 PHP 中 的 表现 就 是 while 循环 。 
while 循环 的 使 用 模式 如 下 : 

TD 


statement 


} 


其 中 的 expr 为 特定 的 条 件 ，statement 为 执行 的 操作 。 下 面 通过 一 个 简单 的 实例 来 说 明 
while 循环 的 使 用 方法 。 
【 例 2.24】 


< 
Wy head> 
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<title> 单 纯 的 while 循环 示例 </title> 


</head> 

<body> 

<?php 

$i=1; /初始 化 变量 
while($i<10) // 判 断 变量 是 否 小 于 10 


// 执 行 操作 1 
// 执 行 操作 2 
// 变 量 增加 


上 面 代码 的 运行 过 程 为 : 程序 先 初始 化 一 个 变量 Si=1， 然 后 判断 变量 是 否 小 于 10， 如 
果 小 于 10， 就 执行 大 括号 内 的 操作 。 当 然 ， 现 在 的 变量 的 值 小 于 10， 于 是 就 打印 出 “第 1 
次 循环 ” 并 自 增 1， 变 量 值 变 为 2。 依 此 类 推 ， 当 循环 执行 到 第 10 次 时 ， 变 量 值 为 10， 
不 再 符合 条 件 ， 于 是 跳出 循环 ， 结 束 整个 过 程 。 执 行 结果 如 图 2.23 所 示 。 
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人 图 2.23 ”while 循环 运行 示例 
[3 


在 使 用 while 循环 时 , 必须 在 while 执行 体 中 使 判断 条 件 的 对 象 有 所 改变 。 如果 没 有 变 
化 ， 就 成 为 死 循环 ， 一 直 执 行 。 如 例 2.26 中 如 果 不 让 变量 自 增 ， 则 变量 的 值 永远 等 于 1， 
循环 就 会 无 休止 地 执行 下 去 ， 直 到 耗 尽 系 统 资源 。 


(2) break 跳出 循环 。 
在 使 用 while 循环 时 ， 有 时 并 不 需要 执行 到 满足 while 要 求 的 条 件 。 在 循环 执行 过 程 中 
就 可 以 对 执行 情况 进行 判断 ， 如 果 满 足 某 一 条 件 就 使 用 break 跳出 循环 。 其 实现 过 程 如 下 : 
while(expr) 
{ 


statement 
这 expD 


break; 人 
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i = 5 时 跳出 ， 不 再 
何 起 作用 的 。 


} 
} 
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break 的 作用 就 是 跳出 当前 循环 , 下面 将 例 2.23 中 的 代码 进行 修改 来 说 明 break 的 使 用 。 


【 例 2.25】 


<head> 

<title>break 跳出 循环 示例 </tite> 
</head> 

<body> 

<2php 

$i=1; 

while($i<10) 


echo "第 ".$i." 次 循环 "; 
echo "<br>"; 

S$i++; 

if($i==5) 

break' 

?> 

</body> 

</html> 


// 初 始 化 变量 
// 判 断 变 量 是 否 小 于 10 


// 执 行 操作 1 

/执行 操作 2 

/变量 增加 1 

/判断 变量 情况 
/满足 条 件 就 跳出 循环 


在 该 例 中 ， 当 变量 $i 为 5 时 ， 就 不 再 返回 继续 循环 ， 而 是 跳出 循环 结束 。 执 行 结果 如 


图 2.24 所 示 。 


| 


GO-@ 


ocdlhost /i tx | 直 


这 收 藉 严 | 荐 breu 吉 出 条 下 示例 


第 1 次 循环 
第 2 次 循环 
第 3 次 循环 
第 4 次 循环 


图 2.24 break 跳出 循环 示例 


可 以 发 现 ， 与 例 2.23 相 比 ， 例 2.25 少 执行 了 几 次 。 如 果 没 有 语句 if($i==5) break:， 程 


序 会 一 直 执行 到 $i<10， 即 当 $i=9 时 依然 是 满足 条 件 的 。 使 用 if($i==5) break; 后 ， 循 环 在 
fj 执行 ， 所 以 看 不 到 第 5、6、7、8、9 次 循环 。 该 例 说 明了 break 是 如 


另外 ,break 除了 可 以 运用 到 while 循环 中 之 外 , 还 能 运用 到 for 循环 以 及 前 面 提 到 的 


(3) continue 语句 。 


switch...case 多 重 判断 中 ， 作 用 都 是 跳出 当前 运行 的 过 程 。 


在 循环 结构 中 ，continue 用 来 跳 过 本 次 循环 中 剩余 的 代码 ， 并 在 条 件 求 值 为 真 时 ， 无 


条 件 执行 下 一 次 循环 。 


下 面 通过 一 个 实例 来 说 明 continue 的 工作 原理 《仍然 采用 前 几 例 的 代码 ， 只 是 做 少许 


改动 ， 这 样 能 更 明白 地 认识 continue 语句 是 如 何 起 作用 的 )。 


【 例 2.26】 
<head> 
<title>continue 语句 示例 </title> 
</head> 
<body> 
<?php 
$i=0; // 初 始 化 变量 
while($i<10) // 判 断 变 量 是 否 小 于 10 
{ 
Sitt+; // 变 量 自 增 
if($i==5) // 判 断 变量 是 否 为 5 
{ 
continue; // 如 果 满 足 条 件 就 跳出 本 次 循环 
} 
echo "第 ".$i." 次 循环 "; // 执 行 操作 1 
echo "<br>"; // 执 行 操作 2 
} 
和 
</body> 
</html> 


在 PHP 环境 下 运行 代码 ， 执 行 结果 如 图 2.25 所 示 。 


cont inue 请 句 示例 LETT F114 
GO rw ne EDI 
帝 收 总 天 | 厦 ontines 滞 可 示例 


和 
图 2.25 ”continue 语句 示例 

从 图 2.25 中 可 以 发 现 ， 语 句 的 第 5 次 循环 并 没有 执行 输出 语句 操作 1 和 操作 2， 执 行 
结果 为 输出 循环 变量 不 为 5 的 内 容 。 

与 break 一 样 ，continue 同样 可 以 用 在 while、for、switch 语句 中 ， 其 作用 原理 也 是 一 
样 的 。 另外， 在 使 用 continue 时 还 要 注意 一 点 ， 即 continue 后 面 的 “;” 是 不 能 省 略 的 ， 
如 果 省 略 会 导致 不 希望 的 结果 出 现 。 

通过 例 2.25 和 例 2.26 可 以 发 现 break 和 continue 语句 的 不 同 。 简单 地 讲 , break 跳出 循 
环 后 ， 后 面 的 循环 也 不 再 进行 ， 即 循环 彻底 结束 ， 而 continue 语句 则 只 是 跳出 了 一 次 循环 ， 
条 件 后 面 的 循环 继续 进行 直至 循环 结束 。 

(4) do..-while 循环 。 
下 面 介绍 一 下 do-while 循环 。 do...while 循环 与 单纯 的 while 循环 不 同 , 单纯 的 while 、 7/ 
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循环 是 先 判断 条 件 是 否 为 真 ， 如 果 为 真 则 执行 ， 否 则 就 不 执行 。 也 就 是 说 ，while 循环 有 
可 能 一 次 也 不 执行 (初始 条 件 是 非 真 的 情况 )。 而 do...while 循环 则 与 此 不 同 ， 它 是 先 执行 
一 次 循环 ， 然 后 再 判断 条 件 是 否 为 真 ， 如 果 为 真 继 续 执 行 ， 否 则 就 跳出 循环 。 其 执行 模式 
如 下 : 


do 

{ 

statement 
}while(exp?); 


下 面 通过 一 个 实例 来 说 明 do...while 是 如 何 起 作用 的 (还 是 使 用 前 面 的 代码 ， 只 是 做 
了 少许 改动 ， 这 样 可 以 更 清楚 地 了 解 它们 之 间 的 异同 )。 
【 例 2.27】 


<head> 

<title>do...while 语句 示例 </title> 

</head> 

<body> 

<2php 

$i=1; 

do 

{ 
echo "第 ".$i" 次 循环 "; // 执 行 操作 1 
echo "<br>"; // 执 行 操作 2 
SBitt; // 变 量 自 增 

} 

while($i<10) // 判 断 变 量 是 否 小 于 10 

Vs 

</body> 

</html> 


执行 结果 如 图 2.26 所 示 。 

运行 结果 和 例 2.24 运行 结果 一 样 。 如 果 将 代码 中 的 while($i<10) 改 为 while($i<1)， 可 
以 分 析 一 下 ， 如 果 是 在 例 2.24 中 ， 那 么 循环 不 会 执行 ， 没 有 任何 输出 结果 ， 而 在 例 2.27 中 
运行 结果 如 图 2.27 所 示 。 


祝 3 次 候 丈 OO- 日 locdhost :国外 D5 
Et 次 收 毫 天 。 税 io， 。. while 语 句 示例 


各 图 2.26 do...while 语句 示例 
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(5) for 循环 。 
和 C 语言 类 似 ，for 循环 是 PHP 中 最 复杂 的 循环 结构 ，for 循环 的 执行 模式 如 下 : 


for(exprl;expr2;expr3) 


statement 


} 


表达 式 中 ，exprl 在 循环 开始 前 无 条 件 地 求 值 1 次 ; expr2 在 每 次 循环 开始 前 求 值 ， 如 
果 值 为 TRUE， 则 继续 循环 ， 执 行 statement 语句 ， 如 果 值 为 FALSE， 则 终止 循环 ，expr3 
在 每 次 循环 结束 后 被 执行 。 

每 个 表达 式 都 可 以 为 宝 。 如 果 expr2 为 空 ， 循 环 无 限 执行 ， 当 然 任何 使 用 者 都 不 想 出 
现 这 种 结果 ， 这 时 可 以 在 循环 体 中 加 入 break 语句 。 当 某 个 条 件 为 真 时 ， 就 执行 break 语 
句 来 跳出 for 循环 。 

下 面 通过 实例 来 实现 for 循环 。 

【 例 2.28】 

<head> 

<title>for 语句 示例 </title> 

</head> 

<body> 

<2php 

for($i=1;$i<10:$i++) 

{ 

echo "第 ".$i" 次 循环 "; // 执 行 操作 1 
echo "<br>"; // 执 行 操作 2 
} 


?> 
</body> 
</html> 


在 PHP 环境 中 运行 ， 执 行 结果 与 图 2.23 一 样 ( 除 了 HTML 显示 的 标题 )。 

3 流程 控制 的 替换 语法 

PHP 提供 了 一 些 流 程控 制 的 替代 语法 ， 包 括 过、while、for、foreach 和 switch。 和 替代 
语法 的 基本 形式 是 把 左 花 括号 “{” 换 成 冒号 “:”, 把 右 花 括号 “} ”分别 换 成 endif;、endwhile;、 
endfor:、endforeach: 以 及 endswitch;。 例 如 : 

<2php if ($a 一 5): ?> 


Aisequalto5 
<?php endif ?> 


在 上 面 的 代码 中 ，HTML 内 容 Ais equalto 5 用 替代 语法 嵌 套 在 f 语句 中 。 该 HTML 
内 容 仅 在 $a= 5 时 显示 。 
替代 语法 同样 可 以 用 在 else 和 elseif 中 。 下 面 是 一 个 包括 elseif 和 else 的 if 结构 
替代 语法 格式 书写 的 实例 。 < hy 
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【 例 2.29】 


<?php 
($a 一 5): 
print "a equals 5"; 
Print "..."; 
elseif ($a 一 0): 
print "a equals 6"; 
print "1 
else: 
print "a is neither 5 nor 6"; 
endif: 


4. 流程 控制 综合 运用 实例 

下 面 通过 一 个 实例 ， 把 判断 与 循环 两 种 方法 结合 起 来 。 通 过 该 实例 ， 巩 固 本 章 所 学 的 
容 。 

例 2.30 实现 的 功能 是 根据 二 维 数组 的 内 容 , 以 表格 的 形式 分 类 打印 出 数组 的 全 部 内 容 ， 


并 以 不 同 的 背景 颜色 显示 大 类 别 及 小 类 别 。 


【 例 2.30】 


<html> 

<head> 

<title> 流 程控 制 综合 运用 实例 </title> 

<head> 

<body> 

<2php 

/首先 定义 一 个 数组 一 一 图 书 类 型 数组 

$type[0][0]=" 学 生 用 书 "; // 第 1 个 大 类 别 
$type[0J[1]=" 学 生 教 材 "; // 第 1 大 类 中 的 第 1 小 类 
$type[0][2]=" 教 辅 用 书 "; 

$type[0][3]=" 课 外 读物 "; 

$type[0][4]=" 考 试题 集 "; 

$type[1][0]=" 名 著 "; // 第 2 个 大 类 别 
$type[1][1]=" 中 国 古典 "; // 第 2 大 类 中 的 第 1 小 类 
$type[1][2]=" 世 界 名 著 "; 

$type[1][3]=" 英 文 原著 "; 

$type[2][0]=" 考 试用 书 "; // 第 3 个 大 类 别 
$type[2][1]=" 公 务 员 "; // 第 3 大 类 中 的 第 1 小 类 
$type[2][2]=" 会 计 师 "; 

$type[2][3]=" 医 药师 "; 

$type[3][0]=" 儿 童 读物 "; // 第 4 个 大 类 别 
$type[3][1]=" 看 图 识字 "; // 第 4 大 类 中 的 第 1 小 类 
$type[3][2]=" 动 漫 人 物 ": 

$type[4][0]=" 武 侠 小 说 "; // 第 5 个 大 类 别 
$type[4][1]=" 金 庸 小 说 "; // 第 5 大 类 中 的 第 1 小 类 
$type[4J[2]=" 古 龙 小 说 "; 

$type[4[3]=" 玄 幻 小 说 "; 


echo "<table border=\"1\">"; 
for($i=0;$i<count($type):$i++) 

{ 

$s=0; 
for($j=0;$j<count($type[$1]);$j++) 
{ 


if($s%2—0) echo "<tr>"; 
$s++; 
这 3 一 0) 
echo "<td colspan=2 bgcolor=\"#ccccO0\">"; 
else echo "<td bgcolor=\"#ccccff\">"; 
echo $type[$i][$j]; 
echo "</td>"; 
这 $j 一 0) 
{ 
$s++; 
} 
if($s%2==0) echo "</tr>"; 
if($s—(count($type[$1])+1) &é& count($type[$1])%2=—0) 


echo "<td bgcolor=\"#ccccff\">&nbsp;</td></tr>"; 

} 

)?> 

</body> 

</html> 

该 例 中 的 流程 控制 比较 复杂 ， 要 考虑 多 种 情况 ， 


// 打 印 表格 头 
// 外 层 循 环 


// 定 义 循环 标识 变量 
// 内 层 循环 


// 如 果 标 识 为 偶数 新 起 
// 标 识 自 增 
// 判 断 是 否 为 大 类 别 
/打印 大 类 别 的 表格 
/打印 小 类 别 的 表格 
// 输 出 数据 
// 表 格 结束 
// 判 断 是 否 为 大 类 别 


/如 果 为 大 类 别 则 标识 再 次 自 增 
/如 果 大 类 别 一 格 或 小 类 别 两 格 则 表格 行 结束 


/判断 小 类 别 项 为 奇数 的 情况 
/在 后 面 添加 空 表格 


如 大 类 别 只 占 一 格 的 情况 、 小 类 别 占 


两 格 的 情况 、 小 类 别 结尾 不 足 i 。 该 例 运 用 了 本 章 学 习 的 判断 、 循 环 知识 ， 同 


时 也 使 读者 了 解 到 , 在 使 用 PHP 编程 时 如 何 使 用 流 
如 图 2.28 所 示 。 


旦 控制 来 处 理 复杂 的 问题 。 其 运行 结果 
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练习 

1. 运算 符 如 何 分 类 ? 

2. 列举 判断 语句 的 分 类 。 
3. 列举 几 种 while 循环 。 
4. 下 面 的 代码 循环 了 几 次 ? 


<?php 
$i=1; 
do 
echo "第 ".$i." 次 循环 "; /执行 操作 1 
echo "<br>"; /执行 操作 2 
Si++; /变量 自 增 
} 
while($i<10) // 判 断 变量 是 否 小 于 10 
?> 


\y/ 
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| 知识 点 、 技 能 点 


> PHP 中 的 函数 及 用 法 
> PHP 中 内 部 函数 

> ”PHP 中 加 载 外 部 函数 
> PHP 中 自 定义 函数 
> PHP 中 的 常用 函数 


掌握 PHP 中 的 函数 及 用 法 
了 解 PHP 中 内 部 函数 和 加 载 外 部 函数 


> 
> 
六 ”掌握 自 定义 函数 用 法 
> 


掌握 PHP 中 的 几 种 常用 函数 


教学 基础 要 求 


> 掌握 PHP 中 的 函数 及 用 法 
六 ”掌握 自 定义 函数 用 法 
> ”了解 PHP 中 的 几 种 常用 函数 
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任务 1 初步 认 训 PHP 中 的 襄 数 


任务 描述 

函数 是 PHP 最 重要 的 组 成 部 分 。 如 果 说 前 面 介绍 的 变量 、 表 达 式 、 流 程控 制 是 PHP 
的 基础 ， 那 么 可 以 说 函数 就 是 PHP 的 主体 。 什 么 是 函数 呢 ? 简 单 地 说 ， 函 数 就 是 为 了 完成 
特定 功能 而 作为 一 个 整体 存在 的 代码 块 。 PHP 中 有 大 量 的 库 函 数 ， 同 时 也 允许 用 户 自 定义 
函数 。 下 面 就 带领 读者 来 认识 一 下 函数 。 本 任务 内 容 包括 什么 是 函数 、 函 数 的 参数 、 函 数 
的 返回 值 、PHP 内 部 函数 的 使 用 、PHP 加 载 外 部 函数 、 自 定义 函数 等 。 

知识 汇总 


3.1.1 什么 是 函数 


简单 地 说 ， 函 数 是 为 了 完成 特定 功能 ， 而 作为 一 个 整体 存在 的 代码 块 。 例 如 ， 求 绝对 
值 函 数 abs0 完 成 的 功能 是 求 一 个 数 的 绝对 值 ， 而 且 它 也 是 独立 存在 的 ， 并 不 受 其 他 变量 或 
函数 的 影响 。 函 数 采 用 以 下 方法 来 定义 。 

function f name($arg) 

{ 

expr; 

return $retval; 


} 


以 上 代码 中 ，f_name 为 函数 名 ， 以 名 字 来 区 别 于 其 他 函数 。$arg 为 函数 的 参数 ， 是 在 
函数 执行 中 要 传递 的 值 ， 在 函数 名 后 面 的 圆 括号 里 。 例 如 ， 如 果 要 求 -3 的 绝对 值 ， 就 要 用 
参数 来 传递 -3， 如 abs(-3)。expr 为 函数 执行 的 语句 。Sretval 为 函数 的 返回 值 ， 指 完成 函数 
后 返回 到 主 程序 中 的 值 ， 但 不 是 每 个 函数 都 有 。 如 abs(-3) 的 返回 值 为 -3 的 绝对 值 3。 其 中 
函数 名 的 命名 规则 与 PHP 中 的 变量 命名 规则 相同 。 有 效 的 函数 名 以 字母 或 下 划 线 开始 ， 后 
面 跟 字母 、 数 字 或 下 划 线 。 

在 PHP 3 中 , 一 个 函数 在 调用 之 前 必须 已 经 被 初始 化 。 如 果 调 用 一 个 未 被 定义 的 函数 ， 
将 会 导致 错误 。 从 PHP 4 开始 ， 就 不 再 有 这 种 限制 ， 这 意味 着 可 以 先 调用 一 个 并 未 被 定义 
的 函数 ， 然 后 再 去 定义 函数 。 但 是 如 果 函 数 的 定义 是 有 条 件 的 ， 那 么 在 这 有 条 件 的 定义 发 
生前 ， 是 不 能 被 调用 的 。 

1. 有 条 件 的 定义 

下 面 以 一 个 实例 来 说 明 有 条 件 的 定义 。 

【 例 3.1】 


<?php 
Smakefoo=true; 


NA 


- 多 一 高等 职业 教育 “十 二 五 " 规划 教材 四 


/不 能 在 这 里 调用 函数 fpo0， 因 为 它 现 在 并 不 存在 ， 但 是 可 以 调用 函数 bar 
barO; // 调 用 函数 bar0 
这 $makefoo) /定义 函数 的 条 件 
function foo0 /定义 函数 foo0 

{ 

echo "T don't exist until program execution reaches me.\n"; // 输 出 字符 串 

> 


} 

/现在 可 以 调用 函数 fpo0 了 ， 因 为 它 已 经 被 定义 

if ($makefoo) foo0; // 调 用 函数 foo0 
function bar0 /无条件 定义 函数 bar0 
{ 

echo "T exist immediately upon program start.\n"; 


} 


Px 


运行 结果 如 图 3.1 所 示 。 


http://1ocalhost/3. 1. php 


GO- 加 locelhost/: lt? [x| | 


全 收 戌 天 请 http://localhost/3.1.php 


I exist immediately upon program start. I don’+t 
exist until program execution reaches me. 


图 3.1 定义 函数 图 示 

以 上 为 第 1 种 情况 ， 虽 然 定义 函数 的 条 件 为 真 ， 但 是 在 有 条 件 的 定义 前 ， 函 数 是 不 能 
被 调用 的 。 即 如 果 某 条 件 为 真 ， 则 再 去 考虑 是 否 去 做 某 件 事 ， 如 果 条 件 不 存在 ， 就 不 考虑 
去 做 这 件 事 ， 更 不 用 说 怎么 去 做 了 。 

这 里 举 一 个 形象 的 例子 。 例 如 ， 一 个 家 长 叫 小 孩 去 买 东西 ， 小 孩 如 何 去 买 东西 可 以 看 
作 是 一 个 函数 。 但 是 小 孩 也 给 家 长 提 了 条 件 ， 如 果 给 1 元 辛苦 费 才 去 买 。 即 只 有 满足 了 给 
1 元 钱 的 条 件 ， 才 去 执行 买 东西 这 个 函数 ， 也 才 去 考虑 怎么 去 买 。 如 果 条 件 根本 不 存在 ， 
那么 函数 就 相当 于 没有 定义 ， 当 然 也 不 会 执行 了 。 

2.， 函数 的 上 谋 套 定义 

第 2 种 情况 是 在 某 一 函数 体 中 定义 另 一 个 函数 。 只 有 当 外 层 函数 被 调用 时 ， 内 层 函 数 
才 会 被 正确 定义 。 所 以 也 只 有 在 调用 外 层 函 数 后 ， 才 能 调用 内 层 函 数 。 下 面 举例 说 明 。 

【 例 3.2】 

<2php 


function foo0) 


function bar0 


echo "IT don't exist until foo() is called.m": N\ 1 
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} 

/现在 不 能 调用 函数 bar0， 因 为 它 还 未 被 定义 

foo0; 

/现在 可 以 调用 函数 bar0， 因 随 着 函数 foo0 的 调用 ， 函 数 bar 也 被 正确 定义 了 
barO; 


?> 


这 种 情况 也 很 容易 理解 ， 与 第 1 种 情况 存在 某 些 相似 之 处 。 只 是 把 定义 函数 的 条 件 转 
化 为 了 某 一 函数 的 执行 。 

如 果 不 把 上 面 例子 中 “家 长 给 钱 ” 看 成 一 个 条 件 ， 而 是 一 个 函数 ， 就 变 成 了 第 2 种 函 
数 的 峰 套 定义 了 。 即 家 长 给 钱 的 函数 执行 了 ， 那 么 孩子 去 买 东西 这 个 函数 就 会 被 定义 ， 然 
后 就 可 以 调用 函数 ， 如 怎么 去 买 东 西 了 。 

另外 ， 在 使 用 函数 时 还 有 一 点 需要 注意 。 与 变量 不 同 ， 函 数 名 是 大 小 写 不 敏感 的 。 如 
定义 的 函数 为 bar0， 实 际 使 用 时 完全 可 以 通过 Bar0 来 调用 它 。 但 通常 情况 下 ,为 了 避免 混 
淆 ， 调 用 时 还 是 使 用 定义 时 的 名 字 。 


3.1.2 ”函数 的 参数 


在 3.1.1 节 介绍 函数 的 定义 时 ， 提 到 了 函数 的 参数 。 定 义 代码 中 的 Sarg 就 是 一 个 参数 。 
PHP 中 的 函数 按 有 无 参数 可 分 为 有 参数 函数 和 无 参数 函数 两 种 。 函 数 参数 只 存在 于 有 参数 
的 函数 之 中 ， 是 指 函 数 名 称 后 圆 括号 内 的 常量 值 、 变 量 、 表 达 式 或 函数 。 当 定义 函数 时 ， 
这 时 的 参数 因为 无 实际 值 ， 所 以 称 为 形式 参数 ， 形 式 参数 不 能 是 常量 值 。 当 调用 该 函数 时 ， 
这 时 的 参数 有 实际 的 值 ， 称 为 实际 参数 。 形 式 参数 的 类 型 说 明 在 函数 名 后 的 括号 之 内 。 

下 面 通过 一 个 简单 的 实例 来 说 明 函 数 参数 的 使 用 。 

【 例 3.3】 


<html> 

<head> 

<title> 函 数 参 数 的 使 用 实例 </title> 

</head> 

<body> 

<?php 

function B_I text($text) // 定 义 有 参数 函数 

{ 

echo "<b><i>" .$text."</></b>"; /打印 字符 并 加 入 粗 体 、 斜 体 效 果 
} 

$string="PHP 编程 是 一 件 很 有 趣 的 事情 "; // 定 义 变量 

echo $string; // 打 印 变量 

echo "<br>"; 

B_I text($string); // 用 实际 参数 调用 函数 
?> 

</body> 

</html> 


TV / 
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函数 参数 的 使 用 实例 - Windows Internet E--- 尾 | 操 ] 必 | 


仿 名 -> 已 1localhost/: 可 | $4 x | 埋 
实 收 训 天 | 大 函数 参数 的 使 用 实例 


PHP 编 程 是 一 件 很 有 趣 的 事情 
PEP 状 娼 旺 一 赃 利 育才 航 移 算 


图 3.2 函数 参数 的 使 用 实例 


例 3.3 中 ， 先 定义 了 有 形式 参数 的 函数 ， 然 后 定义 变量 。 先 显示 变量 ， 再 通过 实际 参 
数 调用 函数 。 从 这 个 例子 中 ， 读 者 可 以 了 解 到 函数 的 参数 是 如 何 传递 值 到 函数 体 的 。 在 使 
用 函数 参数 时 还 应 该 注意 一 个 问题 ， 函 数 的 参数 是 有 类 型 限制 的 ， 即 某 一 函数 的 参数 可 能 
只 对 应 某 一 种 类 型 。 如 果 参 数 的 类 型 与 函数 要 求 的 类 型 不 一 致 ， 就 会 发 生 错 误 ， 可 能 会 返 
用 户 不 希望 的 结果 。 如 函数 absO 的 作用 是 计算 一 个 数 的 绝对 值 ， 所 以 它 的 参数 只 能 为 整 
型 或 者 浮 点 型 数 。 如 果 用 字符 或 者 数组 作为 函数 的 参数 ， 则 一 定 会 出 现 用 户 不 希望 的 结果 。 
另外 ， 有 的 函数 有 默认 值 参数 ， 这 时 的 参数 就 变 成 了 可 选 参数 ， 即 调用 该 函数 时 可 以 不 加 
有 默认 值 的 参数 ， 函 数 将 用 默认 值 来 蔡 换 该 参数 。 下 面 举 一 个 例子 来 说 明 。 

【 例 3.4】 


<html> 

<head> 

<title> 函 数 有 默认 值 参数 的 使 用 实例 </title> 

</head> 

<body> 

<?php 

function B_I text($text,$color="#000000") // 定 义 有 参数 函数 ， 其 中 $color 参数 有 默认 值 
{ 

echo "<font color=".$color.">"; // 使 用 颜色 参数 

echo "<b><i>".$text."</i></b>"; /打印 字符 并 加 入 粗 体 、 斜 体 效 果 
echo "</font>"; 

上 

$string="PHP 编程 是 一 件 很 简单 的 事情 "; // 定 义 变量 

echo $string; // 打 印 变量 

echo "<br>"; 

B_I text($string); // 调 用 函数 ， 无 $color 参数 
Echo "<p>"; 

B_i text($string,"red"); // 调 用 函数 ， 加 入 $color 参数 
Ts 

</body> 

</html> 


运行 结果 如 图 3.3 所 示 。 


加 
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函数 有 默认 值 才 数 的 使 用 实例 - Windows Int 
SO- Br 
宽 收 疗 严 。 御 函 数 有 默认 值 参 数 的 使 用 实例 


PHP 编程 是 一 件 很 简单 的 事情 
PHP 钴 班 硅 一峰 生前 吾 的 荔 萝 
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图 3.3 函数 有 默认 值 参数 的 使 用 实例 
例 3.4 先 定义 了 一 个 有 两 个 参数 的 函数 ， 其 中 $color 参数 有 默认 值 。 即 当 调 用 函数 时 ， 
如 果 不 加 可 选 参数 Scolor， 将 使 用 默认 值 #000000， 即 用 黑色 打印 字体 。 所 以 第 1 次 调用 该 
函数 时 没有 使 用 $color, 打印 出 的 字体 是 黑色 的 。 第 2 次 调用 时 使 用 了 red 作为 Scolor 参数 ， 
则 打印 出 的 字体 就 是 红色 的 。 


3.1.3 ”函数 的 返回 值 


函数 定义 代码 中 的 Sretval 为 函数 的 返回 值 。 函 数 通 过 retum 来 返回 值 。 函 数 的 返回 值 
可 以 是 数值 、 字 符 等 变量 。 下 面 通过 一 个 实例 来 说 明 函 数 的 返回 值 是 如 何 使 用 的 。 
【 例 3.5】 


<html> 

<head> 

<title> 函 数 返 回 值 的 使 用 实例 </title> 

</head> 

<body> 

<2php 

function cube($num) // 定 义 有 参数 函数 

长 

return $num*$num*$num; // 将 参数 连 乘 3 次 的 值 作为 返回 值 
上 

$i=2; 

echo $i." 的 三 次 方 为 : "cube($i); /有 实际 参数 调用 函数 
?> 

</body> 

</html> 


保存 以 上 代码 ， 运 行 结果 如 图 3.4 所 示 。 


函数 返回 值 的 使 用 实例 - 玫 
GD- 加 leealhest/: 癌 | 他 ||X| | 外 Bn 


请 收 京 天 。 | 荐 函数 返 辐 值 的 使 用 实例 


2 的 三 次 方 为 ，8 


图 3.4 函数 返回 值 的 使 用 实例 
另外 ， 函 数 不 能 有 多 个 返回 值 ， 但 是 为 了 返回 多 个 值 ， 可 以 将 数组 作为 一 个 函数 的 返 
\y/ 
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值 。 下 面 通过 一 个 实例 来 说 明 函 数 是 如 何 将 一 个 数组 作为 其 返回 值 的 。 
【 例 3.6】 


<html> 

<head> 

<title> 函 数 将 数组 作为 返回 值 的 使 用 实例 </title> 

</head> 

<body> 

<2php 

function E num($numl,$num2) /定义 函数 有 两 个 参数 

{ 

这 $numl>$num2) /如 果 前 面 数 大 两 者 互 换 
{ 

$temp=$numl; 

$numl=$num2; 

$num2=$temp: 

上 

for($i=$numl:$i<$num2:$i+H) /循环 比较 两 数 之 间 的 值 


if($i%2==0) // 选 出 其 中 的 偶数 

{ 

St[$j]=$i; // 把 结果 赋值 给 数组 元 素 
3j++; 

} 

} 

return $t; // 把 数组 $t 作为 函数 返回 值 
} 

$a=3; // 定 义 变量 

$b=20; 

$c=E_num($a,$b); /1/ 调 用 函数 

echo $a." 到 ".$b." 之 间 的 偶数 为 : " 

for($i=0:$i<count($c):$i++H) // 遍 历数 组 

长 

echo $c[$i]; /显示 结 果 

echo "<br>"; 

} 

?> 

</body> 

</html> 


上 面 代码 定义 了 一 个 函数 E_num($numl.Snum2)， 其 作用 是 求 出 两 个 数 之 间 所 有 的 偶 
数 。 因 为 两 数 之 间 的 偶数 可 能 有 多 个 ， 所 以 要 返回 多 个 数值 。 这 就 要 在 函数 中 把 这 些 数值 
定义 到 数组 中 ,然后 把 数组 当 作 函 数 的 返回 值 返回 。 当 然 函 数 的 返回 值 也 可 能 是 字符 串 等 ， 
这 里 就 不 再 一 一 举例 演示 了 。 


3.1.4 PHP 内 部 函数 


PHP 为 用 户 提供 了 丰富 的 库 函 数 ， 即 内 部 函数 ， 能 否 熟 练 地 使 用 PHP 的 内 部 函数 ， 是 、 (1 
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衡量 一 个 PHP 程序 员 合 格 与 否 的 标准 。 那 么 如 何 使 用 PHP 的 内 部 函数 呢 ? 由 于 内 部 函数 
是 集成 在 PHP 解释 器 中 的 ， 所 以 无 须 定义 ， 可 以 直接 使 用 。 使 用 时 注意 函数 的 参数 类 型 、 
调用 方法 、 返 回 值 及 格式 即 可 。 相 对 于 用 户 自 定义 函数 来 说 ， PHP 的 内 部 函数 使 用 更 简单 。 
一 是 因为 不 用 定义 ;二 是 不 用 担心 函数 体 本 身 会 出 错 。 如 果 在 使 用 库 函 数 时 返回 了 不 希望 
出 现 的 结果 ， 那 么 不 要 怀疑 是 系统 函数 有 问题 。 因 为 这 些 函 数 都 是 经 过 反复 实践 证 明 的 ， 
是 绝对 正确 的 。 下 面 就 通过 实例 来 说 明 在 PHP 中 如 何 使 用 库 函 数 。 

【 例 3.7】 


<html> 

<head> 

<title>PHP 库 函 数 的 使 用 实例 2</title> 
</head> 

<body> 

<?php 

$a[0]=1; 

$a[1]=3; 

$a[2]=2; 

$a[3]=1; 

$a[4]=2; 

$a[5]=1; 

$a[6]=4; 

$a[7]=3; 
print_r(array_count_values ($a)); 
?> 

</body> 

</html> 


运行 结果 如 图 3.5 所 示 。 
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Array ( [1] => 3 [3] => 2 [2] => 2 [4] => 1 ) 


图 3.5 库 函 数 的 使 用 实例 


这 是 一 个 调用 数组 函数 的 实例 ， 可 以 看 出 ，PHP 的 库 函数 有 的 需要 参数 ， 有 的 不 需要 
参数 ， 有 的 需要 多 个 参数 。 所 以 在 使 用 函数 前 ， 了 解 该 函数 的 使 用 方法 是 很 有 必要 的 。 


3.1.5 PHP 加 载 外 部 函数 


PHP 有 很 多 库 函 数 ， 还 有 一 些 函 数 需 要 和 特定 的 PHP 扩展 模块 一 起 编译 ,否则 在 使 用 
它们 时 就 会 得 到 一 个 致命 的 “未 定义 函数 ”错误 。 例 如 ， 要 使 用 图 像 函 数 
imagecreatetruecolor(), 就 需要 在 编译 PHP 时 加 上 对 GD 库 的 支持 具体 做 法 就 是 修改 php.ini 
文件 。 找 到 代码 行 : 
\y/ 
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;extension=php_gd.dll 


把 行 首 的 “;” 去 掉 ， 这 样 PHP 解释 器 在 启动 时 就 会 加 载 GD 库 函 数 ， 然 后 就 可 以 像 使 


用 内 部 库 函 数 一 样 使 用 GD 库 函 数 了 。 


对 其 他 外 部 函数 的 使 用 也 是 如 此 ， 要 使 用 相应 的 函数 ， 就 要 先 加 载 相 应 的 模块 。 有 很 
多 核心 函数 已 包含 在 每 个 版 本 的 PHP 中 ， 如 字符 串 和 变量 函数 等 。 调 用 Phpinfo0 函 数 ， 可 


以 了 解 PHP 加 载 了 哪些 扩展 库 。 同 时 还 应 该 注意 ， 很 多 扩展 库 默 认 就 是 有 效 的 。 
下 面 通过 一 个 实例 ， 来 说 明 如 何 加 载 并 使 用 外 部 函数 。 因 为 要 使 用 GD 库 函 
第 1 步 要 修改 php.ini 文件 ， 去 掉 “;extension=php_gd.dll” 行 首 的 “;”。 另 外 ， 


要 用 到 wingdingsttf 字体 ， 所 以 要 把 wingdings.ttf 字体 文件 复制 到 PHP 文件 的 同 


数 ， 所 以 
在 该 例 中 


全 个 月 孙 


下 。 该 实例 要 实现 的 功能 是 创建 一 个 图 像 文件 ， 并 在 图 像 上 画 出 一 些 图 形 ， 具 体 如 下 。 


【 例 3.8】 
<2php 
Header("Content-type: image/png"); // 输 出 一 个 PNG 图 像 文 件 
S$im=imagecreate(440,100); 1/ 初始化 图 形 区 域 
S$black=imagecolorallocate($im, 0,0,0); // 定 义 黑色 
$white= imagecolorallocate($im, 255,255,255); // 定 义 白色 
$yellow= imagecolorallocate($im,255,255,0):; /定义 黄色 
$blue = imagecolorallocate($im,0,0,255); // 定 义 蓝 色 
S$red= imagecolorallocate ($im,255,0,0); // 定 义 红色 
$zi= imagecolorallocate($im,255,0,255); // 定 义 紫色 
$color=$blue; // 定 义 $color 变量 为 蓝 色 
$font="wingdings.ttf"; // 定 义 字 体 文件 
imagefilledrectangle($im, 5, 5, 435, 95, $color); /用 蓝 色 画 一 个 矩形 
imagestring($im,5,7,10,"I:send",$white): // 用 白色 写字 符 
for($i=0;$1<5;$i++) // 用 循环 画 字符 
{ 
imagettftext($im,40,0,90+$1*50,57,$yellow, $font,"2"); // 将 文字 写 入 图 像 
. 
imagestring($im,5,270,60,"to:YOU As a gift",$white); // 用 白色 写字 符 
imagestring($im,5,305,80,date(Y).".".date(m).".".date(d),$white): // 写 出 当前 日 期 
imagepng($im); // 创 建 图 形 
imagedestroy($im); // 关 闭 图 形 
?> 


大 家 可 以 自己 在 PHP 环境 中 运行 ， 看 一 下 效果 。 
3.1.6 自 定义 函数 


在 实际 进行 PHP 编程 时 ， 由 于 要 面 对 的 情况 可 能 十 分 复杂 ， 仅 仅 依靠 PHP 


内 团 的 库 


函数 有 时 不 能 达到 用 户 的 目的 。 这 时 就 要 用 户 自己 构造 函数 来 解决 实际 问题 。PHP 允许 用 


户 使 用 自 定义 函数 。 那 么 ， 自 定义 函数 应 该 如 何 使 用 ? 本 节 就 来 解决 如 何 使 用 自 
及 函数 的 动态 调用 、 函 数 的 递归 等 问题 。 


中 
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1. 如 何 自 定义 浮 数 
在 PHP 中 ， 自 定义 函数 是 一 件 很 简单 的 事情 ， 只 需 使 用 以 下 语法 格式 就 可 以 完成 对 函 
数 的 自 定义 : 


function functionname() 
{ 

statement; 

return $retval; 

} 


从 以 上 代码 可 见 ， 要 自 定义 函数 ， 就 是 使 用 function 语句 ， 后 面 跟 函 数 名 加 “0”。 
如 果 函 数 需 要 参数 ， 就 把 参数 加 在 括号 内 。 函 数 体 部 分 用 “了” 包括 起 来 ， 以 使 之 与 其 他 
语 名 分开， 其 中 包括 所 要 执行 的 内 容 、 返 回 值 等 。 

下 面 通过 一 个 实例 来 说 明 ， 如 何 完成 函数 的 自 定义 。 

【 例 3.9】 


<html> 

<head> 

<title> 函 数 的 自 定义 实例 </title> 

</head> 

<body> 

<2php 

function my_f($num!1,$num?) /定义 函数 求 两 个 数 的 最 小 公 倍数 
这 $numl>$num2) /如 果 前 面 数 大 两 者 互 换 

{ 

S$temp=$num!l; 

$numl=$num2; 

$num2=$temp; 

} 

$s=$num2; // 定 义 变量 备用 

$i=1; /定义 变量 备用 
while($s%$num1!=0) // 是 否 满 足 最 小 公 倍数 

{ 

$s=$num2*$i: // 大 数 翻 倍 

Bitt; 

} 

return $s; // 返 回 结果 

} 

echo my_f(1,3):; /输出 1 与 3 的 最 小 公 倍数 
echo "<p>"; 

echo my_f(6,8); // 输 出 6 与 8 的 最 小 公 倍 数 
echo "<p>"; 

echo my_f(13,29):; // 输 出 13 与 29 的 最 小 公 倍 数 
echo "<p>"; 

echo my_f(5,100); // 输 出 5 与 100 的 最 小 公 倍 数 
echo "<p>"; 


echo my_f(35,3); // 输 出 35 与 3 的 最 小 公 倍数 
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运行 结果 如 图 3.6 所 示 。 
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加- 已 localhost/: 避 || 壬 | X | | 二 
人 宣 收 着 天 。 荐 函数 的 自 定义 实例 


图 3.6 函数 自 定义 实例 
可 以 看 到 ， 在 代码 的 第 7 行 就 是 自 定 义 的 函数 ， 函 数 作用 为 求 两 个 数 的 最 小 公 倍 数 。 
2， 使 用 自 定义 函数 


自 定义 函数 在 完成 定义 后 ， 就 可 以 使 用 了 。 使 用 的 方法 也 非常 简单 ， 就 像 使 用 PHP 库 
函数 一 样 。 代 码 如 下 
function functionname(); 


函数 名 后 面 加 上 括号 ， 里 面 带 上 适当 的 参数 即 可 。 
例 3.9 中 在 输出 结果 时 echo my_f0 中 的 my_f0 就 是 调用 的 代码 第 7 行 中 自 定义 的 函数 。 
3.， 通 数 的 动态 调用 


由 于 PHP 支持 可 变化 的 函数 概念 ， 所 以 如 果 在 一 个 变量 的 名 称 后 面 加 上 一 对 圆 括号 
“0”， 那 么 PHP 将 去 寻找 与 这 个 变量 名 字 相同 的 函数 。 无 论 这 个 变量 的 数值 是 什么 ， 函 
数 都 会 被 执行 。 这 个 过 程 就 实现 了 函数 的 动态 调用 。 

为 了 形象 地 说 明 函数 的 动态 调用 问题 ， 下 面 通 过 实例 来 介绍 。 

【 例 3.10】 


<html> 
<head> 
<title> 函 数 的 动态 调用 实例 </tile> 
</head> 
<body> 
<2php 
function my _f 1($text) /定义 函数 1 
echo "<font size=5pt>"; // 以 20 号 字体 输出 文字 
echo $text; 
本 
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echo "</font>"; 

上 

function my f 2($text) 
{ 

echo "<font size=5pt>"; 
echo "<u>"; 

echo $text; 

echo "</u>"; 

echo "</font>"; 

. 

S$test="my f 1"; 
Stest("T LIKE PHP!"); 
echo "<p>"; 
S$test="my_f 2"; 


S$test(" 用 PHP 编程 ， 
?> 

</body> 

</html> 


其 实 很 简单 1 路 


运行 结果 如 图 3.7 所 示 。 


4. 函数 的 递归 


// 定 义 函数 2 


// 以 20 号 字体 输出 文字 
// 给 文字 加 上 下 划 线 效果 


/动态 调用 my_f 10 


/| 动态 调 用 my f 20 


函数 的 动态 调用 实例 - LT Internet 


GO-E 


locdlhost/: His x | | 


请 收 大 天 条 函数 的 动态 调用 实例 


I LIKE PHP! 


用 PHP 编程 ， 其 实 很 简单 ! 


图 3.7 函数 的 动态 调用 实例 
以 上 代码 先 定义 了 两 个 函数 ， 然 后 把 函数 名 称 赋值 为 变量 。 变 量 名 后 加 上 括号 ，PHP 
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就 会 去 寻找 同名 的 函数 ， 找 到 后 则 运行 ， 从 而 实现 了 函数 的 动态 调用 。 


下 面 介绍 PHP 函数 的 递归 。 那么 什么 是 递归 呢 ? 其 实 递归 就 像 大 家 熟悉 的 一 个 歌谣 那 


有 说 从 前 有 座 山 ， 山 里 有 座 庙 
是 函数 自身 调用 自身 。 


样 : 从 前 有 座 山 ， 山 里 有 座 庙 ， 庙 里 有 个 老 和 尚 和 一 个 小 和 尚 。 老 和 尚 给 小 和 尚 讲 故 事 ， 
就 像 这 样 无 限 循环 。 回 过 头 来 继续 说 递归 ， 递 归 简 


有 时 通过 函数 的 递归 来 处 理 问 题 是 十 分 有 效 的 。 如 求 斐 波 纳 契 数列 第 N 项 的 值 ， 如 果 


采用 传统 方法 效率 很 低 。 但 如 果 使 用 函数 的 递归 ， 解 决 起 来 就 会 容易 得 多 。 


下 面 就 通过 实例 来 说 明 函 数 的 递归 问题 。 在 列 出 具体 代码 前 ， 先 来 了 解 一 下 斐 波 纳 契 


一 年 后 会 有 多 少 对 兔子 ?这 是 


数列 的 特点 。 斐 波 纳 契 数列 即 “ 兔 子 生 兔子 的 问题 ”: 有 一 个 人 把 一 对 兔子 放 在 封闭 的 地 
方 。 假 定 每 个 月 一 对 兔子 生 下 另外 一 对 ， 而 这 新 生 的 一 对 在 两 个 月 后 生 下 另外 一 对 ， 这 样 
有 对 该 数列 做 一 改动 ， 设 第 一 项 与 第 二 项 为 1， 于 是 形成 这 样 
一 组 数列 : 1，1，2，3，5，8，13，21，34，55，89，144……. 即 某 一 项 为 它 前 面 两 项 之 和 。 


【 例 3.11】 


<html> 

<head> 

<title> 函 数 的 递归 实例 </tile> 
</head> 

<body> 

<2php 

function Fibanacci($num) 
{ 

if($num—=1|| $num——=2) 
return 1; 

else 


{ 


Teturn Fibanacci($num-1)+Fibanacci($num-2); 


} 
} 
echo " 斐 波 纳 契 数列 的 第 1 项 为 :"; 


echo Fibanacci(1); 
echo "<p>"; 

echo " 斐 波 纳 契 数列 的 第 12 项 为 :"; 
echo Fibanacci(12); 
echo "<p>"; 

echo " 斐 波 纳 契 数列 的 第 7 项 为 :"; 
echo Fibanacci(7); 
echo "<p>"; 

echo " 斐 波 纳 契 数列 的 第 20 项 为 :"; 
echo Fibanacci(20); 


运行 结果 如 图 3.8 所 示 。 


在 了 解 了 数列 的 特点 后 ， 下 面 就 通过 使 用 函数 的 递归 来 解决 这 一 问题 。 


/定义 Fibanacci 函数 
/如 果 为 第 1 项 和 第 2 项 
/返回 值 为 1 

// 除 1、2 外 的 其 他 项 


/递归 调用 前 两 项 之 和 
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OE locuhost :ls x se 


以 上 代码 中 ， 当 参数 为 1 或 2 的 情况 很 容易 理解 ， 直 接 返 
直接 返回 和 数组 定义 完全 相同 的 公式 : 某 一 项 为 其 前 两 项 之 和 ， 从 而 实现 了 函数 的 递归 。 
可 以 看 出 ， 使 用 函数 的 递归 解决 此 类 问题 相对 于 用 迭代 法 来 说 是 简单 的 、 有 效 的 。 


请 收藏 天 。 大 函数 的 递归 实 刚 


斐 波 纳 契 数列 的 第 1 项 为 ， 1 
斐 波 纳 契 数列 的 第 12 项 为 ， 144 
斐 波 纳 契 数列 的 第 7 项 为 ，13 
斐 波 纳 契 数列 的 第 20 项 为 ，6765 


图 3.8 函数 递归 实例 


回 1 即 可 。 除 此 以 外 的 情况 


\ 
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另外 ， 在 使 用 函数 递归 时 要 注意 以 下 两 个 问题 : 

回 ”在 递归 中 要 有 使 递归 终止 的 代码 ， 不 能 使 递归 陷入 无 限 循环 之 中 。 

回 ”要 避免 递归 函数 调用 超过 100 一 200 层 的 范围 , 因为 可 能 会 破坏 堆栈 从 而 使 当前 脚 
本 终止 。 

练习 

1. 简 述 函数 的 定义 方法 。 

2. 定义 函数 时 包括 几 个 部 分 ? 

3. 简 述 自 定义 函数 的 方法 。 


任务 2 了 解 PHP 中 的 党 月 西数 


任务 描述 


熟悉 各 种 类 型 的 函数 ， 以 方便 以 后 的 调用 ， 包 括 数组 函数 、 字 符 串 处 理 函 数 、 时 间 日 
期 函数 、 数 学 函数 、 图 像 处 理 函数 、 文 件 系 统 函 数 、 知 识 汇 总 等 。 


知识 汇总 
3.2.1 数组 函数 


数组 是 编程 中 的 重要 元 素 ， 在 PHP 中 也 不 例外 。 在 PHP 语法 部 分 已 经 介绍 了 数组 的 
定义 和 使 用 ， 对 数组 有 了 一 定 了 解 。PHP 中 还 为 用 户 提供 了 一 系列 用 来 操作 数组 的 函数 ， 
这 些 函 数 为 标准 函数 ， 可 以 直接 使 用 。 表 3.1 列 出 了 PHP 5.1.6 提供 的 常用 数组 函数 。 


表 3.1 PHP 5 中 常用 数组 函数 


函 数 名 功 能 
array_change_key_case | 返回 字符 串 键 名 全 为 小 写 或 大 写 的 数组 
array_chunk 将 一 个 数组 分 割 成 多 个 
aay combine 创建 一 个 数组 ， 用 一 个 数组 的 值 作为 其 键 名 ， 另 一 个 数组 的 值 作为 其 值 
array count values 统计 数组 中 所 有 的 值 出 现 的 次 数 
array_fill 用 给 定 的 值 填充 数组 
array_flip 交换 数组 中 的 键 和 值 
array_keys 返回 数组 中 所 有 的 键 名 
array_map 将 回调 函数 作用 到 给 定数 组 的 单元 上 
array Imerge recursive | 递归 地 合并 一 个 或 多 个 数组 
amray_Imerge 合并 一 个 或 多 个 数组 
array_multisort 对 多 个 数组 或 多 维 数组 进行 排序 
array_pad 用 值 将 数组 填补 到 指定 长 度 
array pop 将 数组 最 后 一 个 单元 弹出 〈 出 栈 ) 
array product 计算 数组 中 所 有 值 的 乘积 
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续 表 


函 数 名 功 能 
array_ push 将 一 个 或 多 个 单元 讨 入 数组 的 末尾 〈 入 栈 ) 
array_rand 从 数组 中 随机 取出 一 个 或 多 个 单元 
array_reverse 返回 一 个 单元 顺序 相反 的 数组 
array_shift 将 数组 开头 的 单元 移出 数组 
array_slice 从 数组 中 取出 一 段 
array_splice 把 数组 中 的 一 部 分 去 掉 并 用 其 他 值 取代 
alray_sum 计算 数组 中 所 有 值 的 和 
array_Unique 移 除 数组 中 重复 的 值 
array_unshift 在 数组 开头 插入 一 个 或 多 个 单元 
array_Vvalues 返回 数组 中 所 有 的 值 
amray_walk recursive “| 对 数组 中 的 每 个 成 员 递归 地 应 用 用 户 函 数 
array_ Walk 对 数组 中 的 每 个 成 员 应 用 用 户 函 数 
alTa 新 建 一 个 数组 
arsort 对 数组 进行 逆向 排序 并 
asort 进行 排序 并 


compact 
count 


current 

each 

end 

extract 从 数 负 起 

in aray 检查 数 2 1 

key 从 关联 数组 中 取得 键 名 

krsort 对 数组 按照 键 名 逆向 排序 

ksort 对 数组 按照 键 名 排序 

list 把 数组 中 的 值 赋 给 一 些 变量 

natcasesort 这 算法 对 数组 进行 不 区 分 大 小 写字 母 的 排序 
natsort 然 排 序 算法 对 数组 排序 

next 将 数组 中 的 内 部 指针 向 前 移动 一 位 

prev 将 数组 中 的 内 部 指针 倒退 一 位 

range 建立 一 个 包含 指定 范围 单元 的 数组 

reset 将 数组 中 的 内 部 指针 指向 第 一 个 单元 

rsort 对 数组 逆向 排序 

shuffle 将 数组 打 乱 

sizeof countO 的 别名 

sort 对 数组 排序 

uasort 使 用 用 户 自 定义 的 比较 函数 对 数组 中 的 值 进行 排序 并 保持 索引 关联 
Uksort 使 用 用 户 自 定义 的 比较 函数 对 数组 中 的 键 名 进行 排序 
usort 使 用 用 户 自 定义 的 比较 函数 对 数组 中 的 值 进 行 排序 \ 71/ 
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实际 上 ，PHP 提供 的 数组 操作 函数 多 达 110 多 个 ， 表 3-1 中 并 未 列 出 全 部 函数 ， 而 只 
列 出 了 其 中 较为 常用 的 函数 。 即 使 是 表 中 列 出 的 函数 , 这 里 也 不 可 能 一 一 讲解 其 使 用 方法 。 
下 面 将 着 重 讲解 其 中 最 为 常用 的 几 个 ， 关 于 其 他 函数 ， 读 者 可 以 参考 PHP 手册 来 学 习 。 


/说 明 


有 些 读者 可 能 会 被 这 密密麻麻 的 函数 吓 倒 ， 认 为 学 习 PHP 很 难 。 实际 上 每 一 个 学 习 者 
都 不 可 能 把 所 有 的 函数 都 记 住 。 除 了 少量 的 极为 常用 的 函数 需要 记 住 以 外 ， 其 他 大 多 数 函 
， 数 都 没有 必要 去 死记 硬 背 。 一 种 比较 好 的 学 习 方法 是 将 所 有 函数 浏览 一 遍 ， 并 大 体 记 住 其 
功能 。 等 到 编程 中 遇 到 类 似 问 题 时 ， 可 以 通过 查找 函数 手册 找到 函数 的 使 用 方法 ， 然 后 应 
用 到 程序 中 。 实 际 上 很 多 编程 语言 的 耳 数 库 、 类 库 都 很 庞大 ， 不 可 能 短 时 间 内 全 部 掌握 ， 
都 有 一 个 逐渐 熟悉 、 积 累 的 过 程 。 


FF 


1，arrayO 函 数 


array0 函 数 用 来 建立 一 个 新 数组 ， 函 数 的 参数 可 以 是 混合 类 型 。 下 面 看 一 个 例子 。 
【 例 3.12】 


<html> 

<head> 

<title>array 函数 的 使 用 </title> 
</head> 

<body> 

<2php 

Sarrl=array(0,1,2,3,4); 
$arr2=array("a"=>0,"b"=>1,"c"=>2,"d"=>3,"e"=>4); 
echo "\$arrl[0]=".$arr1[0]; 

echo "<br>"; 

echo "\$arr2[\"a\"]=".$arr2["a"]; 


运行 结果 如 图 3.9 所 示 。 


array 函 数 的 使 用 - Windows Internet Exp... 恬 ] 加 | 医 | 


OO, Br re 


人 宣 收藏 交 | 荐 ray 函数 的 使 用 


$arr1[0]=0 
$arr2["a”]=0 


图 3.9 array0 函 数 的 使 用 


上 述 代码 中 ， 首 先 用 array0 函 数 定义 了 拥有 5 个 元 素 的 数组 Sarr1， 并 且 每 个 元 素 分 别 
赋值 0，1，2，3，4。 然 后 定义 了 同样 拥有 5 个 元 素 的 数组 Sarr2， 并 分 别 赋值 0，1，2，3， 


4。 两 个 数组 的 差别 是 第 一 个 数组 用 了 默认 的 数字 作为 下 标 ， 第 二 个 数组 用 了 自 定义 的 字符 
\ 7 
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作为 下 标 。 因 此 ， 最 后 输出 数组 元 素 时 也 使 用 了 各 自 对 应 的 下 标 。 

2.count0 遂 数 

count0) 函 数 可 以 用 来 统计 一 个 数组 中 元 素 的 个 数 ， 在 循环 遍历 一 个 未 知 长 度 的 数组 时 
非常 有 用 。 下 面 举例 说 明 。 

【 例 3.13】 


<html> 

<head> 
<title>count 函数 的 使 用 </title> 
</head> 

<body> 

<2php 

$arrl=array(0,1,2,3,4); 

Echo "数组 \$arrl 中 元 素 的 个 数 为 :".count($arr1); 
> 

</body> 

</html> 


程序 运行 后 将 输出 “数组 $arrl 中 元 素 个 数 为 ，5”。 

3. each() 函 数 

each(O 函 数 可 以 返回 一 个 数组 中 当前 元 素 的 键 和 值 ， 并 将 数组 指针 向 前 移动 一 步 ， 常 用 
来 在 循环 中 遍历 一 个 数组 。 下 面 举例 说 明 。 

【 例 3.14】 


<html> 

<head> 

<title>each 函数 的 使 用 </title> 

</head> 

<body> 

<2php 

$arr = array("name"=>"Bob","age"=>20,"sex"=>"male", "postcode"= >"100000"); 
for($i=0;$i<count($arr):;$i++){ 
$keyAndValue=each($arr); 

echo $keyAndValue["key"]."=>".$keyAndValue["value"]; 
echo "<br>"; 

} 

?> 

</body> 

</html> 


在 上 面 程序 中 ， 首 先 定义 了 一 个 数组 Sarr， 并 且 为 其 赋值 。 值 得 注意 的 是 ， 数 组 下 标 不 
是 按 顺 序 递增 的 数字 ， 而 是 毫 无 规律 的 字符 串 ， 所 以 不 能 直接 用 一 个 递增 的 数字 作为 下 标 
来 输出 ， 循 环 输出 遇 到 了 困难 。 但 是 使 用 each0 函 数 可 以 获得 该 数组 的 下 标 以 及 下 标 对 应 
的 值 ， 因 此 可 以 使 用 循环 输出 每 一 个 元 素 的 下 标 和 值 。 函 数 each($arr) 将 $arr 数组 中 当前 元 
素 的 下 标 和 值 都 存放 到 另外 一 个 数组 SkeyAndValue 中 ， 然 后 将 数组 指针 指 到 下 一 个 元 素 。 \ 人/_ 
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$keyAndValue 数组 的 下 标 分 别 为 key 和 value。 这 样 只 需要 调用 $keyAndValue["key"] 和 
$keyAndValue["value"] 即 可 获得 该 元 素 的 下 标 和 值 。 输出 这 两 个 值 后 本 次 循环 结束 , 执行 下 
一 次 循环 ， 这 样 又 输出 了 下 一 个 元 素 的 值 ， 依 此 类 推 ， 整 个 数组 都 被 动态 循环 输出 了 。 

通过 例 3.14 大 家 可 以 看 到 each0 函 数 的 妙用 ， 其 实在 countO 函 数 的 例子 中 也 可 以 通过 
each() 来 实现 ， 看 下 面 的 实例 。 

【 例 3.15】 

<html> 

<head> 

<title>each 函数 的 使 用 </tile> 

</head> 

<body> 

<2php 

$arr = array ("name" = >"Bob", "age"=>20, "sex" = >"male", "postcode"=> "100000"); 

While($kav=each($arD){ 

echo $kav["key"]."=>".$kav["value"]; 

echo "<br>"; 


性 

</body> 

</html> 

可 以 看 到 ， 例 3.15 比 用 count0 函 数 更 加 简洁 ， 但 实现 的 效果 却 是 一 样 的 。 上 面 的 代码 
利用 了 each0 函 数 的 一 个 重要 性 质 ， 就 是 当 数 组 到 达 末 尾 时 ，each0 函 数 返回 FALSE。 通 过 
前 面 所 学 的 知识 知道 ，FALSE 是 一 个 布尔 值 ， 表 示 “ 否 ”。 因 此 它 正 好 可 以 作为 while 循环 
的 结束 条 件 。 这 样 ， 可 以 用 一 个 while 循环 来 每 次 读 取 $arr 数组 中 的 一 个 元 素 , 不 管 数组 有 
多 少 个 元 素 ， 当 指针 到 达 末 尾 时 ，each($arD 返 回 FALSE， 循 环 结束 ， 程 序 执行 完成 。 同 样 
实现 了 动态 输出 未 知 长 度 的 数组 的 功能 。 

在 这 里 大 家 可 以 看 到 ， 有 时 候 实 现 同 一 个 功能 可 以 选择 多 种 途径 。 作 为 程序 开发 人 员 ， 
应 该 尽量 选择 更 加 简洁 、 高 效 的 途径 。 

4. current()、reset()、end()、next0) 和 prevO 函 数 

之 所 以 要 将 这 5 个 函数 并 列 起 来 介绍 ， 是 因为 这 5 个 函数 的 作用 相似 ， 都 用 来 操作 数 
组 内 部 的 指针 。 在 PHP 中 ， 使 用 一 个 内 部 指针 来 指向 一 个 数组 。 需 要 访问 数组 中 的 某 一 元 
素 时 ， 只 需要 将 指针 移动 到 该 元 素 的 位 置 ， 即 可 取出 该 元 素 ， 这 大 大 方便 了 用 户 对 数组 的 
操作 。 下 面 先 详 细 说 明 这 5 个 函数 的 作用 ， 然 后 通过 一 个 实例 来 验证 其 使 用 效果 。 


回 ”curent0: 返回 当前 内 部 指针 所 指 的 元 素 的 值 。 当 到 达 数 组 末尾 时 返回 FALSE。 

回 reset0: 将 内 部 指针 指向 数组 的 第 一 个 元 素 并 返回 其 值 。 数 组 为 空 时 返回 FALSE。 

回 end0: 将 内 部 指针 指向 数组 的 最 后 一 个 元 素 并 返回 其 值 。 

回 next0: 将 数组 指针 指向 当前 元 素 的 下 一 个 元 素 并 返回 其 值 。 到 达 末 尾 时 返回 
FALSE。 

回 prev0: 将 数组 指针 指向 当前 元 素 的 上 一 个 元 素 并 返回 其 值 。 到 达 顶 端 时 返回 


7 FALSE。 
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上 面 5 个 函数 的 返回 值 均 为 mixed 类 型 ， 根 据 数组 元 素 值 的 类 型 不 同 而 返回 不 同 的 类 
型 .在 这 里 要 注意 current0 和 mextO 函 数 的 区 别 。 它 们 虽然 都 是 取出 一 个 元 素 值 ,但 是 current() 
函数 并 不 移动 指针 。 也 就 是 说 ，currentO 函 数 返 回 的 是 未 移动 指针 之 前 所 指向 元 素 的 值 ， 而 
nextO 函 数 返 回 的 是 移动 指针 之 后 所 指向 元 素 的 值 。 下 面 来 看 一 个 实例 。 

【 例 3.16】 


<html> 

<head> 

<title> 数 组 内 部 指针 移动 函数 的 综合 应 用 </title> 
</head> 

<body> 

<2php 

$arr=array(1,2,3,4,5,6,7,8,9,10); 

echo "调用 currentO:".current($arr); 

echo "<br>"; 

echo "再 次 调用 currentO:".current($arn); 

echo "<br>"; 
echo "调用 next0:".next($arD); 
echo "<br>"; 
echo "调用 reset():".reset($arr); 
echo "<br>"; 
echo "调用 end0:".end($arr); 
echo "<br>"; 
echo "调用 prevO:".prev($arr); 
?> 

</body> 

</Html> 


运行 结果 如 图 3.10 所 示 。 


数组 内 部 指针 移动 西数 的 综合 应 用 


GO- 而 localhost/: [s+ |x| |S 
全 收藏 天 基数 姐 内 部 指针 移动 函数 的 综合 应 用 


调用 current () :1 
调用 current () :1 

调用 next () :2 

调用 reset 0) :1 

调用 end() :10 

调用 prev0 :9 


图 3.10 数组 内 部 指针 移动 函数 的 综合 应 用 


上 面 程序 中 定义 了 一 个 数组 Sar， 并 且 用 10 个 数字 对 其 进行 了 初始 化 ， 然 后 分 别 调用 
上 述 5 个 函数 来 观察 其 运行 效果 。 为 了 使 输出 结果 直观 ， 在 每 一 次 调用 之 后 都 输出 一 个 
换行 。 
下 面 来 分 析 程 序 的 运行 流程 和 对 应 的 输出 结果 。 
(1) 数组 初始 化 完成 ， 内 部 指针 指向 第 一 个 元 素 〈 元 素 值 为 1)。 
(2) 第 一 次 调用 current0 函 数 ， 返 回 当前 元 素 值 1， 指 针 不 变 。 
wu {4 
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(3) 再 次 调 上 


current0 函 数 ， 由 于 内 部 指针 不 变 ， 仍 然 返回 1。 
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(4) 调用 next0 函 数 ， 内 部 指针 指向 下 一 个 元 素 ， 并 返回 其 值 〈( 返 回 2)。 


(5) 调用 reset0 函 数 ， 内 部 指针 再 次 指向 第 一 个 元 素 ， 返 回 1。 
(6) 调用 end0 函 数 ， 内 部 指针 指向 最 后 一 个 元 素 ， 并 返回 其 值 ( 返 回 


kat 


0)。 


(7) 调用 prev0 函 数 ， 内 部 指针 指向 前 一 个 元 素 ， 并 返回 其 值 ( 返 回 9)。 


关于 PHP 的 数组 函数 就 介绍 到 这 里 。 如 果 对 表 3.1 中 列 出 


其 他 函数 感 兴趣 ， 可 以 自 


行 编写 程序 进行 测试 。 函 数 的 参数 、 返 回 值 类 型 等 均 可 以 通过 查看 PHP 手册 获得 。 


3.2.2 ”字符 串 处 理 函 数 


在 Web 编程 中 , 字符 串 是 使 用 最 为 频繁 的 数据 类 型 之 一 。 因为 PHP 不 是 一 门 强国 类 型 
化 语言 ， 因 此 很 多 数据 都 可 以 方便 地 作为 字符 串 来 处 理 。 字 符 串 操 作 是 编程 中 极为 常用 的 


操作 ， 从 简单 的 打印 输出 


- 行 字符 串 到 复杂 的 正则 表达 式 等 ， 处 理 目标 都 是 字符 串 。PHP 


提供 了 大 量 实用 的 函数 ， 可 以 帮助 用 户 完成 许多 复杂 的 字符 串 处 理工 作 。PHP 提供 的 常用 


字符 串 处 理 函 数 及 其 功能 如 表 3.2 所 示 。 
表 3.2 PHP 常用 的 字符 串 处 理 函 数 及 其 功能 


函 数 名 功 能 
addcslashes 当中 一 样 使 用 反 斜 线 转 义 字符 串 中 的 字符 
addslashes 使 用 反 斜 线 引 用 字符 串 
bin2hex 将 二 进 制 数据 转换 成 十 六 进 制 表示 
chop 去 除 字符 串 右 侧 空格 
chr 返回 指定 的 字符 
chunk split 将 字符 串 分 割 成 小 块 


将 字符 由 一 种 Cyrillic 字符 转换 成 另 
对 一 个 未 编码 字符 串 进行 编码 
对 一 个 字符 串 进行 解码 


convert_cyr_string -种 
convert_ uudecode 


convert_uuencode 


count_chars 返回 字符 串 所 用 字符 的 信息 
crc32 计算 一 个 字符 串 的 crc32 多 项 式 
echo 输出 字符 串 

explode 使 用 一 个 字符 串 分 割 另 一 个 字符 串 
fprintf 将 格式 化 字符 串 写 入 流 
html_entity decode | 将 HTML 标记 转换 为 特殊 字符 
htmlspecialchars 将 特殊 字符 转换 为 HTML 标记 
implode 合并 数组 元 素 到 一 个 字符 串 中 
join implode0 函 数 的 别名 

ltrim 去 除 字符 串 左 侧 空 格 

md5 file 用 mq5 算法 对 文件 进行 加 密 


/ 


函 数 名 功 能 
md5 用 md5 算法 对 字符 串 进行 加 密 
nl2br 将 换行 符 蔡 换 成 HTML 的 换行 符 <br> 


Dumber format 


将 一 个 数字 格式 化 成 三 位 一 组 


ord 返回 一 个 字符 的 ASCI 码 

print 输出 字符 串 

printf 输出 格式 字符 串 

rtrim 去 除 字符 串 右 侧 空格 

sprintf 返回 一 个 格式 字符 串 

str pad 用 一 个 字符 串 填充 另外 一 个 字符 串 到 一 定 长 度 
str_ Tepeat 重复 输出 一 个 字符 串 

str replace 字符 串 蔡 换 

str_ shuffle 随机 打 乱 一 个 字符 串 

str_split 将 字符 串 转换 成 数组 


str word_ count 


统计 字符 串 中 的 单词 数 


strchr 找 一 个 子 个 字符 串 中 第 一 次 出 现 的 位 置 ， 并 返回 从 此 位 置 开 始 的 字符 串 
stremp 字符 串 比 较 大 小 

strip tags 过 滤 掉 字符 

strlen 获得 字符 串 的 长 度 〈 所 占 字 节 数 ) 

strpbrk 以 子 串 中 的 任意 一 个 字符 第 一 次 出 现 的 位 置 为 界 将 字符 串 分 成 两 部 分 ， 并 返回 后 半 部 分 
strpos 查找 一 个 子 E 串 中 第 一 次 出 现 的 位 置 

strrpos 查找 一 个 子 串 中 最 后 一 次 出 现 的 位 置 

strrev 将 一 个 字符 串 顺 序 倒转 

strrchr 查找 一 个 字符 在 一 个 字符 串 中 最 后 一 次 出 现 的 位 置 并 返回 从 此 位 置 开始 之 后 的 字符 串 
strstr strchr 函数 的 别名 

strtok 将 字符 串 打 碎 成 小 段 

strtolower 3 中 的 字符 全 部 变 为 小 写 

strtoupper 将 字符 串 中 的 字符 全 部 变 为 大 写 

strtr 批量 字符 替换 


substr_count 


Substr_ replace 


统计 一 个 子 串 在 字符 串 中 出 现 的 次 数 
在 字符 串 内 部 定制 区 域内 替换 文本 


substr 截取 字符 串 的 一 部 分 

trim 去 除 字符 串 首尾 的 连续 空格 
ucfirst 将 字符 串 首 字母 大 写 

Ucwords 将 字符 串 中 每 个 单词 的 首 字母 大 写 


NI 
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1.， trim0O、ltrimn0、rtrim(0、chop0 和 strlen0 浮 数 

这 5 个 函数 中 前 4 个 函数 的 功能 类 似 , 因此 将 其 放 在 一 起 介绍 。 chop0 与 rrim0) 函 数 作 
用 相同 ， 都 是 去 除 字符 串 右 端的 空格 。ltrim0 函 数 用 来 去 除 字符 串 左 端的 空格 ， 而 tim0 函 
数 用 来 去 除 字 符 串 左 右 两 端的 空格 。 

下 面 来 看 一 个 实例 ,其 中 用 到 了 另外 一 个 字符 串 处 理 函 数 stlen0 来 获得 字符 串 的 长 度 。 

【 例 3.17】 


<html> 

<head> 

<title> 去 除 字符 串 两 端 空格 </title> 

</head> 

<body> 

<?php 

$str="” 你 看 不 到 我 我 是 空格 " 

echo " 方 括号 中 为 原始 字符 串 : r' .$str."]<br>"; 

echo "原始 字符 串 长 度 : ".strlen($str)."<br>"; 
$strl=ltrim($stD; 

echo "执行 lrim0 之 后 的 长 度 :".strlen($str1)."<br>"; 
$str2=rtrim($str); 

echo "执行 rtrim0 之 后 的 长 度 :".strlen($str2)."<br>"; 
$str3=trim($str); 

echo "执行 trim0 之 后 的 长 度 ".strlen($str3)."<br>"; 
echo "去 掉 首 尾 空格 之 后 的 字符 串 : [".$str3."]"; 

> 

</body> 

</html> 


运行 结果 如 图 3.11 所 示 。 


去 除 字 符 囊 两 端 空格 


个 外 - 上 €] localhost/: | #9 xX | | 址 
请 收 U 天 和 去 队 了 符 中 两 入 衬 格 


六 区 时 中 为 原始 宁 符 中， [ 你 看 不 到 我 我 是 空格 ] 
原始 字符 串 长 度 : 

执行 trin0 世 各 的 表 度 ， 20 
执行 rtrim() 之 后 的 长 度 ，21 
执行 trim() 之 后 的 长 度 19 

去 乔 基 放空 和 之 月 的 字 衬 由 ， [你 看 不 到 我 我 是 空格 ] 


图 3.11 去 除 字符 串 两 端 空格 实例 
在 上 面 程 序 中 ， 首 先 构造 了 一 个 字符 串 $str， 该 字符 串 由 9 个 汉字 和 4 个 空格 组 成 ，4 
个 空格 中 有 2 个 在 左 侧 ，1 个 在 中 间 ，1 个 在 右 侧 〈 由 于 浏览 器 会 忽略 掉 连 续 的 空格 ， 因 此 
在 浏览 器 中 两 个 连续 空格 的 显示 效果 与 一 个 空格 相同 )。 由 于 每 个 汉字 占 2 个 字 节 ， 每 个 
英文 半角 空格 占 1 个 字 节 ,因此 初始 字符 串 的 长 度 为 9X2 十 4=22。 用 strlen0 函 数 来 输出 其 
长度 。 
首先 执行 ltrim0 函 数 ， 将 返回 结果 存放 在 $strl 中 。 由 于 lrim0 函 数 会 去 掉 字符 串 左 侧 
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的 所 有 连续 的 空格 ， 因 此 两 个 空格 被 去 掉 ，$strl 的 字符 串 长 度 为 20。 

然后 执行 rtrim0) 函 数 , 将 返回 结果 存放 在 $str2 中 。rtrim0) 函 数 去 掉 了 字符 串 $str 右 侧 的 
1 个 空格 ， 因 此 $str2 的 长 度 为 21。 

最 后 执行 tim0 函 数 。trim0) 函 数 去 除 字符 串 左右 两 侧 的 所 有 空格 ， 因 此 左 侧 的 2 个 空 
格 和 右 侧 的 1 个 空格 被 去 掉 ， 剩 余部 分 长 度 为 19。 通 过 $str3 的 输出 也 可 以 看 出 ， 字 符 串 两 
侧 的 空格 已 经 消失 。 

去 除 连续 的 空格 往往 用 在 做 字符 串 比较 之 前 。 比 较 两 个 字符 串 是 否 相 同时 ， 如 果 其 中 
一 个 字符 串 首 尾 带 有 空格 ， 那 比较 结果 就 会 为 假 。 如 "abc" 和 "abc "这 两 个 字符 串 ， 看 似 内 
容 完全 相同 ， 但 由 于 后 者 后 面 多 了 一 个 空格 ， 在 比较 时 会 返回 FALSE。 因 此 ， 比 较 两 个 字 
符 串 变量 的 值 是 否 相同 时 ， 往 往 首先 用 trim0 函 数 处 理 一 下 两 侧 的 空格 。 

值得 注意 的 是 ，trim 系列 函数 只 去 除 字符 串 两 侧 的 空格 ， 而 不 会 去 除 中 间 的 空格 。 如 
例 3.17 中 ,“ 你 看 不 到 我 ”和 “我 是 空格 ”之 间 有 一 个 空格 。 调 用 这 3 个 函数 之 后 空格 仍 
然 存在 ， 说 明 字符 串 中 间 的 空格 不 会 受 影响 。 如 果 想 去 除 一 个 字符 串 中 的 所 有 空格 ， 可 以 
使 用 后 面 要 讲 的 字符 串 替 换 函 数 来 实现 。 

2. ucwords()、ucfirst()、strtoupper()、strtolower() 和 str_word_countO 函 数 

这 5 个 函数 对 字符 串 中 的 单词 进行 处 理 ， 包 括 转换 大 小 写 、 计 算 单 词 个 数 等 。 下 面 通 
过 一 个 实例 来 了 解 它 们 的 用 法 。 

【 例 3.18】 

<html> 

<head> 

<title> 字 符 串 处 理 中 的 单词 处 理 </title> 

</head> 

<body> 

<2php 

$str="ni hao, wo jiao Wang Xiao-ming."; 

echo "原始 字符 串 : ".$str"<br>"; 

$strl=ucfirst($str); 

echo "执行 ucfirst0 之 后 : ".$strl."<br>"; 

$str2=ucwords($str); 

echo "执行 uewords0 之 后 : ".$str2."<br>"; 

$str3=strtoupper($str); 

echo "执行 strtoupper0 之 后 : ".$str3."<br>"; 

$str4=strtolower($str); 

echo "执行 strtolower0 之 后 : ".$str4."<br>"; 

echo "字符 串 中 一 共有 :".str_word_count($str)." 个 单词 。"; 


运行 结果 如 图 3.12 所 示 。 
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字符 串 处 理 中 的 单词 处 理 - Windows Interne-- 
GO BE rv x 


窗 收 京 天 。 篇 字符 串 处 理 中 的 单词 处 理 


始 字符 串 ，ni hao，wo jiao Wang Xiao-ming. 
可 0 〇 之 后 ,Ni hao, wo jiao Wang Xiao- 


多 入 woworas 0 之 后 ， WH Hao, Wo Jiao Wang Xiao- 


ming. 
执行 strtoupper 0) 之 后 ，NIT HAD，WO JIAD WANG 
XIAD-MING。 
执行 strtolower () 之 后 ，ni hao，wo jiao wang 
xiao-ming， 


字符 囊 中 一 共有 ，6 个 单词 。 


图 3.12 字符 串 处 理 中 的 单词 处 理 


上 面 的 代码 中 构造 了 一 个 包含 6 个 单词 、 大 小 写 混合 的 字符 串 ， 并 用 它 来 测试 函数 的 
运行 结果 。 程 序 调用 ucfirst(0) 函 数 将 整个 字符 串 首 字 母 变 为 大 写 ， 调 用 ucwords() 函 数 将 每 
个 单词 的 首 字 母 变 为 大 写 ， 调 用 strtoupper0 函 数 将 全 部 字母 都 变 成 大 写 ， 调 用 strtolower() 
函数 将 所 有 字母 变 成 小 写 ， 最 后 调用 str_word_count() 函 数 统计 字符 串 中 的 单词 个 数 。 

3. 字符 串 查 找 函 数 

程序 中 经 常用 到 在 一 个 字符 串 中 查找 某 个 字符 或 者 某 个 子 串 的 操作 、 对 字符 串 中 的 某 
些 字 符 按 照 用 户 的 需求 进行 替换 操作 以 及 截取 字符 串 的 一 部 分 等 。PHP 中 提供 了 一 系列 函 
数 实 现 这 些 操 作 ， 用 户 只 需要 了 解 函数 的 使 用 方法 即 可 轻松 实现 。 

常用 的 字符 串 查 找 函数 有 substr_countO0、strposO0、stmpos0O、strsttr0 和 strrchr0 等 。 它 
们 的 使 用 方法 和 功能 介绍 如 下 。 

(1) substr_count0 函 数 。 

substr_count0) 函 数 的 格式 为 : 


int substr_count ( string haystack, string needle [, int offset [, int length]] ) 


substr_count(0) 函 数 用 来 统计 一 个 字符 串 needle 在 另 一 个 字符 串 haystack 中 出 现 的 次 数 。 
该 函数 返回 值 是 一 个 整数 。 有 两 个 可 选 参 数 : offset 和 length， 分 别 表示 要 查找 的 起 点 和 长 
度 。 值 得 注意 的 是 ，offset 是 从 0 开始 计算 ， 而 不 是 从 1 开始 计算 的 。 
【 例 3.19】 


<html> 

<head> 

<title> 用 substr_count0 函 数 统计 字符 串 出 现 次 数 </title> 
</head> 

<body> 

<2php 

$str="T am an abstract about abroad.": 
echo substr_count($str,"ab"); 

echo ™ 

echo substr_count($str,"ab",6,4); 

?> 


\y/ 
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</body> 
</html> 


本 例 的 输出 结果 为 “3，1”。 

substr_count($str,"ab") 的 作用 是 返回 字符 串 ab 在 字符 串 $str 中 的 次 数 ， 由 于 ab 在 整个 
字符 串 中 出 现 了 3 次 ， 因 此 值 为 3。 

substr_count($str,"ab",6,4) 的 作用 是 返回 字符 串 ab 在 $str 中 的 从 第 6 个 字符 开始 (包含 
第 6 个 字符 ,而 且 从 0 开始 计算 ), 往 后 数 4 个 字符 为 止 ( 即 第 9 个 字符 ) 之 间 的 字符 串 中 
出 现 的 次 数 。 这 个 描述 非常 抛 口 和 难 懂 ， 不妨 换 一 种 描述 方法 : 参数 6，4 限定 了 查找 字符 
串 的 范围 。 不 指定 参数 时 ，substr_count0) 函 数 从 整个 字符 串 $str 中 查找 ab 出 现 的 次 数 ， 而 
指定 了 参数 之 后 ，substr_countO 函 数 从 指定 的 范围 内 查找 ab 出 现 的 次 数 。 这 个 范围 就 是 从 
字符 串 的 第 6 个 字符 开始 到 第 9 个 字符 为 止 的 4 个 字符 。 具 体 到 本 例 中 ， 就 是 n ab 〈 注 
意 n 和 a 之 间 的 一 个 空格 也 算 一 个 字符 )。 显 然 ， 在 这 个 范围 内 ，ab 只 出 现 了 1 次 ， 因 此 
返回 1。 

(2) strrpos0 和 strpos() 函 数 。 
strrpos0 〇 函数 的 格式 为 : 


int strrpos ( string haystack, mixed needle [, int offset] ) 


该 函数 返回 字符 needle 在 字符 串 haystack 中 最 后 一 次 出 现 的 位 置 。 这 里 needle 只 能 是 
-个 字符 ， 而 不 能 是 一 个 字符 串 。 如 果 提 供 一 个 字符 串 ，PHP 也 只 会 取 字 符 串 的 第 一 个 字 
符 ， 其 他 字符 无 效 。 参 数 offset 用 来 限制 查找 的 范围 。 
strposO 函 数 的 格式 为 : 


int strpos ( string haystack, mixed needle [, int offset] ) 


该 函数 与 strrpos0 函 数 仅 一 个 字母 之 差 ， 但 功能 相差 很 大 。strpos0 函 数 中 的 needle 参 
数 允 许 使 用 一 个 字符 串 ， 而 且 返 回 的 是 该 字符 串 在 haystack 中 第 一 次 出 现 的 位 置 ， 而 不 是 
最 后 一 次 出 现 的 位 置 。 

【 例 3.20】 


<html> 

<head> 

<title> 字 符 串 查找 函数 的 使 用 (一 〉</tile> 

</head> 

<body> 

<?php 

$str="I am an abstract about abroad.": 

echo "原始 字符 串 为 : ".$str"<br>"; 

echo "ab 在 字符 串 中 的 第 一 次 出 现 位 置 为 : "stpos($str"ab") "<br>": 
echo "ab 在 字符 串 中 的 最 后 一 次 出 现 位 置 为 : "stmpos(Sstr"ab) "<br> 
echo "abcd 在 字符 串 中 第 一 次 出 现 的 位 置 为 :".strpos(S$str,"abcd"); 
?> 

</body> 


</html> NI 
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…… 项 目 3 PHP 中 函数 的 学 习 国 


运行 结果 如 图 3.13 所 示 。 
2 字符 串 查找 函数 的 使 用 (一 ) ws Inter- 
GO-E localhost/: | x | | 外 5c 


这 收 京 天 “起 字 符 审 查找 函数 的 使 用 (一) 


am an Ee es abroad. 


原始 字符 串 为 

中 在 字符 届 中 的 第 一 站 红 
和 于 中国 六 后 类 归 和 是 盖 % 23 
abcd 在 字符 串 中 第 一 次 出 现 的 位 置 为 ， 


图 3.13 字符 串 查找 函数 的 使 用 〈 一 ) 


上 面 程序 中 首先 构造 了 一 个 包含 多 个 ab 的 字符 串 。 然 后 分 别 调用 sttpos0 和 strrpos() 
函数 来 获得 ab 子 串 在 字符 串 中 第 一 次 和 最 后 一 次 出 现 的 位 置 ， 输 出 结果 为 8 和 23。 这 里 
有 两 点 值得 注意 : 第 一 点 是 8 和 23 都 是 从 0 开始 计算 的 , 而 且 是 从 子 串 的 第 一 个 字母 出 现 
的 位 置 开始 计算 。 如 子 串 为 ab， 找 到 ab 之 后 ， 以 a 的 位 置 序号 作为 函数 的 返回 值 ， 而 不 是 
b 的 位 置 序号 ; 第 二 点 是 如 果 要 查找 的 字符 串 不 存在 ， 则 返回 布尔 值 FALSE。 由 于 FALSE 
无 法 直接 输出 ， 因 此 最 后 查找 abcd 子 串 时 没有 任何 输出 。 

(3) strstr0 和 strrchr0 函 数 。 
strstr() 和 strrchrO 函 数 的 格式 分 别 是 : 


string strstr ( string haystack, string needle ) 
String strrchr ( string haystack, string needle ) 


由 此 可 见 ， 这 两 个 函数 均 返 回 一 个 字符 串 ， 而 不 是 返回 一 个 表示 位 置 的 整数 。 两 个 函数 
名 称 不 同 ， 使 用 方法 完全 相同 ， 但 是 其 作用 略 有 不 同 。strstr0 函 数 用 来 查找 一 个 子 串 needle 
在 字符 串 haystack 中 第 一 次 出 现 的 位 置 ， 并 返回 从 此 位 置 开始 的 字符 串 。strrchr() 函 数 查找 
-个 字符 needle 在 字符 串 haystack 中 最 后 一 次 出 现 的 位 置 ， 并 返回 从 此 位 置 开始 之 后 的 字 
符 串 。 
【 例 3.21】 


<html> 

<head> 

<title> 字 符 串 查找 函数 的 使 用 (二 ) </title> 

</head> 

<body> 

<?php 

$str=" 千 山 鸟 飞 绝 ， 万 径 人 踪 灭 ， 孤 舟 萎 等 伍 ， 独 钓 寒 江 雪 。"; 

echo "1. 原 始 字 符 串 为 :".$str."<br>"; 

echo "用 strstr 函数 搜索 “, ”的 返回 结果 : ".strstr($str,", 达 式 "). "<br>"; 
echo "用 strstr 函数 搜索 “ 孤 舟 ”的 返回 结果 :".strstr($str," 孤 舟 "). "<br>"; 
$str2="T have a great dream."; 

echo "2. 原 始 字 符 串 为 :".$str2."<br>"; 

echo strrchr($str2,"e"); 

echo "<br>"; 

echo strrchr($str2,"at"): 

?> 


字符 囊 查找 函数 的 使 用 (二 ) - Windows Inter--- 若 | 加 | 了] 
GO- [HN localhost = 加 | 好 | X| 请 
突 收 京 天 。 乱 字 罕 审 查找 函数 的 使 用 二) 


1. we ed 万 径 人 踪 灭 ， 班 舟 蒜 


用 strstr 证 

体 ， 独 钓 寒 江 雪 。 

2. 原 始 字符 串 为 ,I have a great dream. 
eam. 

am. 


图 3.14 字符 串 查找 函数 的 使 用 〈 二 ) 


通过 深入 分 析 本 例 的 输出 结果 ， 就 能 够 准确 地 把 握 strstr0 和 strrchrO 函 数 的 功能 特点 。 

首先 ， 在 第 一 个 字符 串 中 ， 用 strstr0 函 数 搜索 逗号 “,”。 该 函数 返回 字符 串 中 第 一 次 
出 现 “, ”的 位 置 之 后 的 字符 串 。 由 于 第 一 次 出 现 辟 号 是 在 “ 千 山 鸟 飞 绝 ” 的 “ 绝 ” 字 之 后 ， 
因此 , 函数 的 返回 结果 是 “, 万 径 人 踪 灭 ……”( 注 意 逗 号 本 身 也 会 被 返回 )。 为 了 证 明 strstr() 
函数 可 以 使 用 一 个 字符 串 而 不 仅仅 单个 字符 作为 参数 ， 又 在 字符 串 中 搜索 “ 孤 舟 ”， 显然 应 
当 返 回 “ 孤 舟 著 等 伍 ……”。 和 程序 的 运行 结果 相同 。 

然后 ， 又 构造 了 一 个 英文 字母 构成 的 字符 串 [have a great dream.。 用 strrchr0) 函 数 在 字 
符 串 中 查找 e， 返 回 字 符 串 中 最 后 一 次 出 现 e 的 位 置 之 后 的 内 容 ， 程 序 中 3 次 出 现 e， 但 最 
后 一 次 出 现 是 在 dream 中 ， 于 是 函数 返回 eam.〈e 本 身 也 被 返回 )。 最 后 测试 是 否 可 以 把 一 
个 字符 串 作 为 参数 传递 给 strrchr0 函 数 ,在 字符 串 中 查找 字符 串 at。 如 果 该 函数 支持 字符 串 
参数 ， 按 照 上 面 的 分 析 ， 应 当 返 回 at dream.。 但 是 根据 图 3.14 的 运行 结果 可 知 ， 返 回 的 却 
是 am.。 这 是 因为 strrchr0) 函 数 不 支 持 字 符 串 参数 ， 如 果 提 供 了 字符 串 参数 ， 会 自动 截取 字 
符 串 的 第 一 个 字符 作为 参数 。 也 就 是 说 ， 参 数 at 和 参数 a 所 起 的 作用 一 样 。 于 是 函数 返回 
字符 串 中 最 后 一 次 出 现 a 之 后 的 内 容 即 am.。 

可 能 有 读者 会 问 , 为 什么 要 构造 一 个 英文 的 字符 串 来 讲解 strrchr0 函 数 呢 ? 通 过 刚才 的 
分 析 就 能 够 得 到 答案 。 因 为 每 一 个 汉字 都 占 两 个 字 节 ， 在 函数 中 两 个 字 节 会 被 认为 是 多 个 
字符 (英文 中 一 个 字符 占 一 个 字 节 )。 因 此 ，strrchr0 函 数 无 法 支持 中 文 。 也 就 是 说 不 能 把 
一 个 或 多 个 中 文字 符 作为 参数 传递 给 strrchr0 函 数 。 

除了 strrchr0 函 数 之 外 ，PHP 中 还 有 很 多 函数 无 法 直接 处 理 中文 ， 这 里 不 一 一 列 出 , 读 
者 在 学 习 PHP 和 编写 程序 时 应 当 多 加 注意 。 

4.， 字符 串 替换 函数 

字符 串 蔡 换 是 Web 编程 中 极为 常用 的 操作 ， 如 要 过 滤 掉 用 户 提交 的 不 文明 的 词语 、 处 
理 掉 字 符 串 中 包含 的 危险 脚本 或 替换 掉 某 些 关 键 词 等 。PHP 提供 了 一 些 函数 来 完成 字符 串 
替换 操作 ， 如 nl2br0、str_replace0) 等 。 

NI 
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一 一 一 项 目 3 PHP 中 函数 的 学 习 国 


(1) nl2br0 函 数 。 


该 函数 的 名 称 中 间 包 含 一 个 数字 “2”， 英文 为 two， 与 to 谐音 ， 实 际 上 就 是 to 的 一 种 
缩写 。 在 很 多 中 文 参考 资料 中 ， 将 此 函数 的 功能 描述 为 “将 换行 符 蔡 换 成 HTML 的 换行 符 
<br>”， 本 书 也 沿用 这 一 解释 。 但 是 如 果 查 阅 英 文 版 PHP 手册 ， 会 发 现 大 意 为 “在 每 一 行 


前 插入 HTML 换行 标记 <br>”。 也 就 是 说 是 “插入 ”而 不 是 “替换 ”。 但 是 我 们 在 使 月 
数 时 , 就 其 效果 而 言 相当 于 “替换 ”因此 本 书 采用 一 贯 的 解释 , 将 其 归 为 字符 串 蔡 换 
下 面 通过 一 个 简单 的 例子 来 说 明 此 函数 的 作用 。 
【 例 3.22】 


<html> 

<head> 

<title>nl2br0 函 数 的 使 用 </title> 
</head> 

<body> 

<form action="6-11.php" method="post"> 
请 输入 一 段 包 含 回 车 的 文字 ，<br> 


nen 


<input type=submit value=" 提 交 看 效果 "> 
</form> 

<2php 

$content=$_ POST["content"]; 
if($content!=""){ 

echo "<hr>"; 

echo "直接 输出 接收 到 的 内 容 : <br>"; 
echo $content; 

echo "<br> (内 容 长 度 : "strlen($contenb.") <br>"; 

echo "<hr>"; 

echo "用 nl2brO 处 理 接收 到 的 内 容 ， 然 后 输出 : <br>"; 
echo nl2br($content); 

echo "<br> (内容 长 度 : "strlen(nl2br($contenb).") <br>"; 
} 

?> 

</body> 

</html> 


/如 果 用 户 输入 内 容 不 为 空 


日 此 函 
函数 。 


本 程序 首先 创建 了 一 个 textarea 多 行文 本 输入 框 ， 并 要 求 输 入 一 段 包含 回 车 的 文字 。 
之 所 以 要 求 包含 回 车 ， 是 因为 nl2br0 函 数 处 理 的 对 象 就 是 回 车 。 如 果 不 包 含 回 车 ， 就 无 法 


测试 其 效果 。 不 妨 输入 “ 子 丑 寅 卯 展 已 午 未 必 申 西 戌 效 ”， 其 中 “ ”表示 按 一 次 


Enter 


键 。 这 时 单 击 “ 提 交 看 效果 ”按钮 ， 通 过 运行 大 家 可 以 深刻 地 了 解 到 nl2brO 函 数 的 作用 : 

在 未 使 用 nl2br0 函 数 对 接收 到 的 内 容 进行 处 理 时 ， 本 来 输入 了 3 行内 容 ， 但 在 网 页 中 显示 
时 全 都 连 成 了 一 行 。 这 是 因为 HTML 语言 不 识别 回 车 换行 符号 ， 无 论 在 HTML 代码 中 连 
续 输入 多 少 个 回 车 换行 ， 都 不 会 在 网 页 上 看 到 效果 。 用 nl2br0 函 数 对 内 容 进行 处 理 后 ， 每 


一 行 前 面 都 自动 添加 了 一 个 < 这 标记 ， 该 标记 就 是 通常 用 的 HTML 中 的 换行 标记 <br 


>, 不 


过 是 写法 略 有 不 同 而 已 。 原 本 输入 的 3 行内 容 ， 便 正常 地 显示 出 来 。 

此 外 ， 通 过 比较 nl2br0 处 理 前 后 字符 串 的 长 度 ， 也 可 以 看 出 此 函数 的 工作 原理 。 未 处 
理 之 前 ,提交 的 数据 内 容 由 12 个 汉字 和 两 个 回 车 换行 构成 ,长 度 为 12X2 十 2X2=28 (每 
次 按 下 Enter 键 都 会 产生 一 个 换行 和 一 个 回 车 两 个 字符 )。 而 用 nl2br0 函 数 处 理 之 后 ， 数 据 
内 容 长 度 变 成 40， 增 加 了 12 字 节 。 而 12 字 节 恰好 是 2 个 <br> 的 长 度 〈 注 意 br 和 /之 间 的 
室 格 也 占 一 个 字 节 )。 因 此 , 足以 证 明 nl2br0 函 数 的 作用 是 在 被 处 理 的 字符 串 中 每 一 行 之 前 
插入 一 个 <br> 标 记 。 

虽然 nl2br0 函 数 的 本 质 并 没有 进行 替换 ， 但 在 使 用 中 ， 其 效果 等 同 于 将 回 车 换行 符号 
替换 为 HTML 换行 标记 。 因 此 ， 在 不 严格 要 求 的 前 提 下 ， 可 以 称 之 为 字符 替换 函数 。 

(2) str_replace0 〇 函数。 

PHP 提供 的 str_replaceO 函 数 将 一 个 字符 串 中 的 任意 子 串 全 部 替换 为 另外 一 个 子 串 ， 其 
使 用 格式 如 下 : 


mixed str_replace ( mixed search, mixed replace, mixed subject [, int &count] ) 


该 格式 看 起 来 有 点 复杂 ,简单 地 解释 为 : str_replace(0) 函 数 将 subject 中 的 所 有 search 替 
换 成 replace, 并 把 替换 的 次 数 存放 在 count 中 。 其中, count 参数 为 可 选 参数 。 这 里 的 search、 
repalce、subject 以 及 整个 函数 的 返回 值 都 是 mixed 类 型 ， 也 就 说 提供 的 参数 可 以 是 多 种 类 
型 ， 常 用 的 有 字符 串 和 数组 。 

【 例 3.23】 


<html> 

<head> 

<title> 字 符 串 替换 函数 综合 范例 </title> 
</head> 

<body> 

<2php 

/单个 字符 替换 

$str= " 当 所 有 的 人 [去] 离开 我 的 时 候 [ 逗 ] 你 劝 我 要 耐心 等 候 [ 句 ]"; 
echo " 原 字符 串 : <b>".$str."</b><br>"; 

$str = str_replace("[","(",$str); 

$str = str_replace("]",")",$str); 

echo "字符 替换 之 后 : <b>".$str."</b><br>"; 

// 字 符 串 替换 

$str = str_Teplace("( 逗 )","，",$stD; 

$str = str_replace("( 句 )","。",$stD); 

echo "字符 串 替换 之 后 : <b>".$str."</b><br>"; 
和 

</body> 

</html> 


运行 结果 如 图 3.15 所 示 。 
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字符 率 车 换 函 数 综 合 范例 
SO- 


请 收 总 天 。 科 字符 串 莹 的 函数 皖 合 范例 


原 字符 串 ， 当 所 有 的 人 [ 逗 ] 离 开 我 的 时 候 [ 喜 ] 你 劝 


我 要 耐心 
人 当 所 有 的 人 (去 ) 离 开 我 的 时 候 ( 逗 ) 
Eb 有 的 人 ， 离 开 我 的 时 候 ， 你 


图 3.15 字符 串 替换 函数 综合 范例 


以 上 代码 中 构造 了 一 个 字符 串 ， 其 中 逗号 用 “[ 逗 ]” 表 示 ， 句 号 用 “[ 句 ]” 表 示 。 第 
9 一 10 行 分 别 进行 了 两 次 蔡 换 ， 将 字符 “[”、“]” 分 别 替换 成 “(”、“)”， 然后 输出 蔡 换 后 
的 字符 串 。 在 第 13 一 14 行 又 进行 了 两 次 蔡 换 ， 将 “( 逗 )” 替 换 成 “,”， 将 “( 句 )” 替 换 成 
“。”， 然 后 将 最 终 的 字符 串 输 出 。 

上 面 的 程序 主要 用 到 了 str_replace0 函 数 的 普通 字符 串 替 换 功 能 。str_replaceO 函 数 还 可 
以 接收 一 个 数组 参数 ， 来 实现 批量 的 替换 ， 如 例 3.24 所 示 。 

【 例 3.24】 


<html> 

<head> 

<title> 字 符 串 替换 函数 高 级 应 用 </title> 
</head> 

<body> 

<2php 

/单个 字符 替换 

$str= " 当 所 有 的 人 [去 ] 离 开 我 的 时 候 [ 逗 ] 你 劝 我 要 耐心 等 候 [ 句 ]"; 
echo " 原 字符 串 : <b>".$str."</b><br>"; 
Sarrl= array("[","]"); 

$arr2= array("(",")"); 

$str = str_replace($arrl,$arr2,$str); 

echo "字符 替换 之 后 : <b>".$str."</b><br>"; 


// 字 符 串 替换 
$arr3= array(" (过 )"， "A: 
$arr4 = array(", ","。"); 


$str = str_replace(Sar3, $arr4, $str); 
echo "字符 串 替 换 之 后 : <b>".$str."</b><br>"; 


可 以 发 现 ， 在 本 程序 中 使 用 str_replace0 函 数 时 传递 了 两 个 数组 作为 参数 ， 第 1 个 数组 
按 顺序 存放 了 要 被 替换 的 字符 串 ， 第 2 个 数组 按 顺序 存放 了 要 替换 成 的 字符 串 。 这 样 ， 不 
论 要 蔡 换 多 少 个 字符 串 ， 只 要 按照 顺序 分 别 存放 在 两 个 数组 中 ， 然 后 调用 str_repalce0 函 数 
即 可 完成 ， 这 样 做 有 明显 的 优点 ， 在 要 替换 的 项 目 很 多 的 情况 下 ， 可 以 很 大 程度 地 简化 程 
序 ， 使 其 运行 速度 更 快 。 
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5. 字符 串 截 取 函 数 


编程 中 经 常 遇 到 要 将 一 个 字符 串 的 一 部 分 单独 取出 的 情况 , 也 就 是 字符 串 的 截取 。 PHP 


中 常用 的 字符 串 截取 函数 有 substrO 等 。 


substr() 函 数 的 使 用 格式 如 下 : 


string substr ( string string, int start [, int length] ) 


本 函数 返回 一 个 字符 串 中 从 指定 位 置 开始 指定 长 度 的 子 串 。 参 数 string 为 原始 字符 串 ， 


start 为 截取 的 起 始 位 置 〈 从 0 开始 计 )， 可 选 参数 length 为 要 截取 的 长 度 。 值 得 一 提 的 是 ， 
参数 start 和 length 均 可 以 用 负数 ，start 为 负数 时 说 明 从 倒数 第 start 个 字符 开始 取 ; length 
为 负数 时 表示 从 start 位 置 开始 取 ， 向 前 取 length 个 字符 结束 。 


【 例 3.25】 


<html> 

<head> 

<title> 字 符 串 的 截取 </title> 

</head> 

<body> 

<2php 

/构造 字符 串 

$str ="ABCDEFGHIJKLMNOPQRSTUVWXYZ":; 
echo " 原 字 符 串 : <b>".$str."</b><br>"; 

// 按 各 种 方式 进行 截取 

$strl= substr($str,5); 

echo "从 第 5 个 字符 开始 取 至 最 后 : ".$strl."<br>": 
$str2= substr($str,9,4); 

echo "从 第 9 个 字符 开始 取 4 个 字符 :".$str2."<br>"; 
$str3= substr($str,-5); 

echo " 取 倒 数 5 个 字符 : ".$str3."<br>"; 

$str4 = substr($str,-8,4); 

echo "从 倒数 第 8 个 字符 开始 向 后 取 4 个 字符 :".$str4."<br>"; 
$str5 = substr($str,-8,-2); 

echo "从 倒数 第 8 个 字符 开始 取 到 倒数 第 2 个 字符 为 止 :".$str5."<br>" 
?> 

</body> 

</html> 


运行 结果 如 图 3.16 所 示 。 


字符 囊 的 截取 


GO- [3 aeeahesv: 国 后 jx 十 
请 收 庆 天 。 | 蒋 字 符 审 的 本 取 


原 字符 囊 ，ABCDEFGHIJKLENOPQRSTUVWXYZ 

从 第 5 个 字符 开始 取 至 最 后 ，FGHI JKLINOPQRSTUVWXYZ 
从 第 9 个 和 JELN 

取 倒 数 5 个 字符 

从 站 类 等 5 趟 字符 中 二 向 后 了 个 字符 ， 

和 个 字符 开始 到 到 合 数 第 21 字符 为 上 ， 


图 3.16 字符 串 的 截取 
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通过 例 3.25 读者 应 当 对 substr0 函 数 有 一 个 深入 的 了 解 ， 尤 其 是 start 和 length 两 个 参 
数 的 含义 和 使 用 方法 ， 更 应 该 熟练 掌握 。 有 一 点 值得 注意 ，start 参数 为 正 数 时 ， 从 0 开始 
计数 ，start 参数 为 负数 时 ， 从 1 开始 计数 。 也 就 是 说 没有 “倒数 第 0 个 字符 ”。 读 者 可 以 参 
考 本 例 加 深 理解 ， 也 可 以 自己 动手 编制 一 个 程序 来 验证 。 

6. 字符 串 分 割 函 数 

在 编程 中 有 时 需要 将 一 个 字符 串 按 某 种 规则 分 割 成 多 个 。PHP 提供 了 explode0、 
str_split0) 等 函数 来 完成 分 割 操作 。 下 面 分 别 介 绍 这 两 个 函数 。 

(1) explode() 函 数 。 
explode0 函 数 的 格式 如 下 : 


array explode ( string separator, string string [, int limit] ) 


explode0 函 数 用 来 将 一 个 字符 串 按 照 某 个 指定 的 字符 分 割 成 多 段 ， 并 将 每 段 按 顺序 存 
入 一 个 数组 中 。 该 函数 的 返回 值 就 是 一 个 数组 。separator 参数 为 分 割 符 ， 可 以 是 一 个 字符 
串 ， 也 可 以 是 单个 字符 。string 为 要 处 理 的 字符 串 。 参 数 limit 为 可 选 ， 如 果 设 置 了 limit， 
则 返回 的 数组 包含 最 多 limit 个 元 素 ， 最 后 一 个 元 素 将 包含 string 的 剩余 部 分 。 

【 例 3.26】 


<html> 

<head> 

<title>explode 字符 串 分 割 函数 </title> 
</head> 

<body> 

<2php 

/构造 字符 串 

$str = "苹果 ， 空 心 菜 ， 香 获 ， 萝 卜 ， 大 蒜 ， 牛 肉 "; 
echo " 原 字符 串 : <b>".$str."</b><br>"; 
echo "1. 以 逗号 为 分 割 符 分 割 字 符 串 : <br>"; 
Sarrl= explode(", ",$str); 

echo "---\$arr1[0] 的 值 : ".$arr1[0]."<br>"; 
echo "---\$arl[4] 的 值 : ".$arr1[4]."<br>"; 
echo "2 .分 割 时 指定 limit 参数 : <br>"; 
$arr2= explode(", ",$str,3); 

echo "---\$arr2[0] 的 值 : ".$arr2[0]."<br>"; 
echo "---\$arr2[2] 的 值 : ".$arr2[2]."<br>"; 
echo "---\$arr2[4] 的 值 : ".$arr2[4]."<br>"; 
Ts 

</body> 

</html> 


运行 结果 如 图 3.17 所 示 。 


yy 


多 一 训 等 职业 教育 “十 二 五 ” 规 攻 村 ©® 


PHP+MySQL 天 全 贡 上 孝王。 | 


ezplode 字 符 目 分 割 函 数 - Windows Interne--- 必 | 后 | 属 | 
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俩 收 辣 赤 。 有 cplode 字 符 审 分 类 洱 数 


站 苇 果 ， 空 心 菜 ， 香 匡 ， 萝卜 ， 大 医 ， 和牛 
» 于 汶 全 的 守 条 要 
] 的 值 ， 苹果 


二 
一 arr2[2] 的 值 ， 香 芒 ， 药 卜 ， 大 藉 ， 牛 内 


图 3.17 explode 字符 串 分 隔 函 数 


上 面 程序 中 ,定义 了 一 个 普通 字符 串 $str。 字 符 串 中 出 现 了 多 个 逗号 ,， 用 explode0 函 数 
来 分 隔 这 个 字符 串 ， 把 “, ”作为 分 割 字 符 。 在 未 提供 limit 参数 的 情况 下 ,字符 串 被 分 成 6 
小 段 ， 并 存 入 数组 $arrl 中 。 每 一 小 段 分 别 对 应 $arr[0]，$arr[1]，.……，$arr[5]。 然 后 指定 limit 
参数 为 3， 再 次 用 explode0O 函 数 分 隔 字 符 串 $str， 这 时 返回 的 数组 $arr2 只 包含 3 个 元 素 ， 
即 $arr2[0]，$arr2[1]，$arr2[2]。 这 时 $arr2[2] 中 存放 的 不 是 第 3 个 喜 号 之 前 的 内 容 ， 而 是 第 
2 个 逗号 之 后 的 所 有 内 容 。 

(2) str_split0 函 数 。 

str_split(0) 函 数 的 格式 为 : 


array str_split ( string string [, int split_length] ) 


str_split() 函 数 将 - ee - 定 长 度 为 单位 分 割 成 多 段 ， 并 返回 由 每 一 段 组 成 的 数 
组 。str_splitO 函 数 不 是 以 某 个 字符 串 为 分 割 依据 ， 而 是 以 一 定 长 度 为 分 割 依据 。 参 数 string 
为 要 分 割 的 字符 串 ， 可 选 参数 length 设置 分 割 的 单位 长 度 

【 例 3.27】 


<html> 

<head> 

<title>str_split 字符 串 分 割 函 数 </title> 
</head> 

<body> 

<?php 

/分 割 英文 字符 串 

$str = "Quietly Ileavejust as quietly I came."; 
echo " 原 字 符 串 : <b>".$str."</b><br>"; 

echo "1 .以 默认 长 度 分 割 字符 串 : <br>"; 
$arrl= str_split($str); 

echo "--\$arr1[0] 的 值 : ".$arr1[0]."<br>"; 
echo "---\$arr1[1] 的 值 :".$arr1[1]."<br>"; 
echo "---\$arr1[10] 的 值 :".$arr1[10]."<br>"; 
echo "2. 以 指定 长 度 5 分 割 字 符 串 : <br>"; 
$arr2= str_split($str,5); 

echo "---\$arr2[0] 的 值 : ".$arr2[0]."<br>"; 
echo "---\$arr2[1] 的 值 : ".$arr2[1]."<br>"; 
echo "--\$arr2[5] 的 值 :".$arr2[5]."<br>"; 
/测试 分 割 中 文 \、7Yy 
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$str2=" 轻 轻 地 我 走 了 ， 正 如 我 轻 轻 地 来 。"; 
echo " 原 字 符 串 : <b>".$str2."</b><br>"; 
echo "1. 以 指定 长 度 5 分 割 字 符 串 : <br>"; 
$arr3= str_split($str2,5); 

echo "---\$arr3[0] 的 值 : ".$arr3[0]." <br>"; 
echo "---\$arr3[1] 的 值 : ".$arr3[1]." <br>"; 
echo "2. 以 指定 长 度 4 分 割 字 符 串 : <br>"; 
$arr4 = str_split($str2,4); 

echo "---\$arr4[0] 的 值 : ".$arr4[0]." <br>": 
echo "---\$arr4[1] 的 值 : ".$arr4[1]." <br>"; 
echo "---\$arr4[4] 的 值 : ".$arr4[4]." <br>"; 


?> 

</body> 

</html> 

至 行 结果 如 图 3.18 所 示 。 
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二 时 肛 6， 

一 -$arr2[0] 的 值 ，Quiet 

一 -$arr2[1] 的 值 ，ly I 

一 -$arr2[5] 的 值 ，uietl 

原 字 符 串 ， 轻 轻 地 我 走 了 ， 正 如 我 轻 轻 地 来 。 
1. 以 指定 长 度 5 分 着 字 符 串 ， 

一 -$arr3[0] 的 值 ， 轻 轻 0 


一 -$arr4[4] 的 值 ， 如 我 
图 3.18 str_split 字符 串 分 割 函数 


上 述 代码 首先 构造 了 一 个 英文 字符 串 ， 然 后 用 str_split0 函 数 直接 分 割 。 分 割 之 后 字符 
串 被 一 个 字符 一 个 字符 地 分 割 开 来 ， 并 且 顺 次 存放 到 数组 $arrl 中 。 接 下 来 指定 分 割 的 单位 
os 
到 正确 的 输出 结 
前 面 已 名 an 一 个 汉字 字符 占 2 个 字 节 ， 很 多 字符 串 处 理 函 数 并 不 能 很 好 地 支 
持 中 文 。 为 了 测试 str_splitO 函 数 分 割 中 文 的 效果 ， 又 构造 了 一 个 字符 串 ， 该 字符 串 全 部 由 
汉字 字符 构成 。 首 先 用 5 作为 分 割 单位 来 分 割 字符 串 ， 通 过 输出 结果 可 以 看 出 ，str_split() 
函数 无 法 区 别 中 文 ， 如 $arr3[0] 的 值 不 是 “ 轻 轻 地 我 走 ”5 个 汉字 字符 ， 而 是 “ 轻 轻 口 ?。 这 
里 为 什么 会 有 一 个 “ 口 ” 呢 ?这 个 口 不 是 字符 串 中 的 , 而 是 在 分 割 字符 串 时 将 第 3 个 字 “ 地 ” 
分 割 成 了 两 段 ， 因 为 无 法 正确 显示 这 个 字符 ， 只 能 显示 为 “ 口 ”。 
为 了 解决 这 个 问题 ， 又 用 一 个 偶数 4 作为 分 割 长 度 ， 这 时 汉字 可 以 正确 显示 ， 整 个 字 
符 串 以 2 个 汉字 字符 为 单位 被 分 割 成 多 段 。 也 就 是 说 ， 在 分 割 中 文 时 ， 分 割 长 度 必 须 是 2 
a 的 倍数 ， 否 则 将 会 导致 汉字 被 分 成 两 段 而 无 法 正确 显示 
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纵然 如 此 ， 使 用 函数 时 的 分 割 方案 还 有 不 完美 之 处 ， 那 就 是 当 一 个 字符 串 是 由 中 、 英 
文 或 者 中 文 与 阿拉 伯 数 字 混 合 而 成 时 ， 即 使 用 2 的 倍数 作为 分 割 长 度 ， 仍 然 无 法 避免 汉字 
被 分 割 的 情况 。 如 字符 串 “110 是 一 个 重要 的 电话 号 码 ” 如 果 以 2 或 4 作为 分 割 长 度 ， 都 
会 导致 “是 ”这 个 汉字 被 分 割 。 因 此 ， 在 使 用 str_splitO 函 数 时 必须 充分 考虑 汉字 的 影响 ， 
否则 会 产生 不 可 预料 的 结果 。 

关于 字符 串 处 理 函 数 就 介绍 到 这 里 。 字 符 串 处 理 函 数 在 编程 中 使 用 极为 频繁 ， 读 者 应 
当 熟 练 掌握 ， 多 多 积累 。 上 面 介绍 的 都 是 字符 串 处 理 函 数 中 最 为 常用 的 部 分 ， 另 外 还 有 大 
量 的 函数 限于 篇 幅 无 法 一 一 介绍 ， 读 者 可 以 参考 表 3.2 及 PHP 官方 手册 自行 学 习 、 掌 握 ， 
为 后 面 深入 学 习 PHP 编程 打下 基础 。 
虽然 在 讲解 时 每 个 函数 都 是 独立 地 讲解 ， 但 读者 应 注意 这 些 函数 的 结合 使 用 。 在 一 个 
程序 中 ， 可 能 会 同时 用 到 多 个 函数 ， 通 过 多 个 函数 的 综合 应 用 来 实现 一 个 操作 ， 因 此 读者 
应 在 这 方面 多 下 工夫 。 


3.2.3 时 间 / 日 期 函数 


时 间 / 日 期 函数 用 来 获取 服务 器 的 时 间 和 日 期 ， 或 对 时 间 / 日 期 类 型 的 数据 进行 各 种 处 


用 户 进行 某 些 操作 的 时 间 等 。PHP 5 提供 的 时 间 / 日 期 函数 如 表 3.3 所 示 。 
表 3.3 PHP 中 的 时 间 / 日 期 函数 


函 数 名 功 能 
checkdate 验证 一 个 格 里 高 里 日 期 
date default timezone get 取得 一 个 脚本 中 所 有 时 间 / 日 期 函数 所 使 用 的 默认 时 区 
date_default_ timezone _set 设 定 用 于 一 个 脚本 中 所 有 时 间 / 日 期 函数 的 默认 时 区 
date_sunrise 返回 给 定 的 日 期 与 地 点 的 日 出 时 间 
date_sunset 返回 给 定 的 日 期 与 地 点 的 日 落 时 间 
date 格式 化 一 个 本 地 时 间 / 日 期 
getdate 取得 时 间 / 日 期 信息 
gettimeofday 取得 当前 时 间 
gmdate 格式 化 一 个 GMT/UTC 时 间 / 日 期 
gmmktime 取得 GMT 日 期 的 UNIX 时 间 惟 
gmstrftime 根据 区 域 设置 格式 化 GMT/UTC 时 间 / 日 期 
idate 将 本 地 时 间 / 日 期 格式 化 为 整数 
localtime 取得 本 地 时 间 
microtime 返回 当前 UNIX 时 间 改 和 微 秒 数 
mktime 取得 一 个 日 期 的 UNIX 时 间 惟 
strftime 根据 区 域 设置 格式 化 本 地 时 间 / 日 期 
strptime 解析 由 strftime0 生 成 的 时 间 / 日 期 
strtotime 将 任何 英文 文本 的 时 间 / 日 期 描述 解析 为 UNIX 时 间 戳 
time 返回 当前 的 UNIX 时 间 戳 


uf 
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通过 表 3.3 可 以 看 到 ，PHP 提供 了 很 多 函数 实现 各 种 时 间 / 日 期 操作 。 其 中 不 乏 很 有 趣 
的 函数 ， 如 返回 某 给 定 日 期 与 地 点 的 日 出 /日 落 时 间 。 不 过 其 中 部 分 函数 并 没有 很 大 的 实用 
价值 ， 只 需要 熟练 掌握 其 中 几 个 函数 的 使 用 ， 即 可 实现 绝 大 多 数 常见 的 应 用 。 

值得 一 提 的 是 表 中 UNIX 时 间 戳 的 概念 ， 很 多 读者 可 能 不 明白 什么 是 UNIX 时 间 戳 。 
UNIX 时 间 惟 是 指 从 UNIX 纪元 〈 格 林 威 治 时 间 1970 年 1 月 1 日 00 时 00 分 00 秒 ) 开始 
到 当前 时 间 为 止 相隔 的 秒 数 。 很 显然 UNIX 时 间 惟 应 该 代表 一 个 很 大 的 整数 。UNIX 时 间 
戳 在 很 多 时 候 非常 有 用 ， 尤 其 在 对 时 间 进 行 加 减 时 作用 最 为 明显 。 如 当前 时 间 是 2006 年 
10 月 10 日 10 点 10 分 10 秒 ， 在 这 个 时 间 基 础 上 加 上 25 天 8 小 时 55 分 58 秒 ， 会 得 到 一 
个 什么 时 间 呢 ? 可 能 推算 起 来 比较 复杂 。 因 为 除了 时 间 进 位 以 外 ， 还 涉及 不 同月 份 天 数 可 
能 不 同 ( 可 能 是 28 天 、29 天 、30 天 、31 天 )。 所 以 用 数学 方法 直接 加 减 是 不 行 的 。 如 果 
使 用 UNIX 时 间 戳 ， 在 第 一 个 时 间 的 基础 上 加 上 一 定 的 秒 数 ， 得 到 的 就 是 第 二 个 时 间 的 
UNIX 时 间 戳 ， 然 后 用 PHP 的 有 关 函 数 把 这 个 时 间 惟 转 换 成 普通 时 间 格 式 显示 即 可 。 

【 例 3.28】 

<html> 

<head> 

<title> 获 取 UNIX 时 间 惟 </title> 

</head> 

<body> 

<2php 

$tm= time(); 

echo "当前 时 间 的 UNIX 时 间 惟 为 : "$tm: 

?> 

</body> 

</html> 


上 面 的 代码 用 于 获取 UNIX 时 间 惟 ， 运 行 结果 会 因 当 前 时 间 的 不 同 而 不 同 ， 这 里 不 青 


演示 。 

在 PHP 中 ,还 提供 了 mktime() 和 strtotime0) 函 数 来 获取 指定 时 间 的 UNIX 时 间 戳 的 
操作 。 

mktime() 函 数 的 格式 如 下 : 


int mktime ( [int hour [, int minute [, int second [, int month [, int day [, int year]]]]]] ) 


本 函数 的 作用 是 根据 给 出 的 参数 返回 UNIX 时 间 戳 。6 个 参数 全 都 是 整数 ， 分 别 代 表 
小 时 、 分 钟 、 秒 、 月 、 日 、 年 。 参 数 可 以 从 右 向 左 省 略 ， 任 何 省 略 的 参数 会 被 设置 成 本 地 
期 和 时 间 的 当前 值 。 当 全 部 参数 都 被 省 略 时 ， 获 得 的 就 是 当前 时 间 的 UNIX 时 间 戳 。 

strtotime(O 函 数 允 许 使 用 一 个 时 间 字 符 串 作为 参数 来 获取 UNIX 时 间 惟 。 该 时 间 字 符 串 
的 顺序 与 中 文 习 惯 较为 吻合 , 如 2000-11-1210:34:55 表示 2000 年 11 月 12 日 10 时 34 分 55 
秒 。 该 字符 串 指 代 了 一 个 具体 的 时 间 ， 可 以 作为 strtotime0 函 数 的 参数 ， 来 获得 该 时 间 的 
UNIX 时 间 惟 。 两 个 函数 的 用 法 都 比较 简单 ， 这 里 不 再 举例 说 明 。 
前 面 学 习 了 如 何 获得 一 个 时 间 的 UNIX 时 间 戳 。 虽 然 用 UNIX 时 间 惟 有 利于 在 计算 机 
| 
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中 进行 时 间 的 计算 ， 但 是 在 显示 时 间 时 还 是 应 该 显示 成 通用 的 年 、 月 、 日 、 时 、 分 、 秒 以 
及 星期 几 等 格式 , 而 不 是 直接 输出 一 个 UNIX 时 间 戳 。PHP 中 提供 了 getdate0 和 date0 等 函 
数 来 实现 从 UNIX 时 间 惟 到 通用 时 间 / 日 期 的 转换 。 

(1) getdateO 函 数 。 

getdate() 函 数 用 来 将 一 个 UNIX 时 间 戳 格式 化 成 具体 的 时 间 / 日 期 信息 ， 其 使 用 格式 
如 下 : 


arTray getdate ( [int timestamp] ) 


其 中 参数 timestamp 为 一 个 UNIX 时 间 蕉 。 如 果 不 指定 参数 ， 则 默认 使 用 当前 时 间 。 
该 函数 返回 一 个 数组 ， 数 组 中 存放 了 详细 的 时 间 信 息 。 通 过 数组 下 标 可 以 取得 数组 中 的 元 
素 值 。 其 下 标 与 值 的 对 应 关系 如 表 3.4 所 示 。 


表 3.4 getdate() 函 数 返 回 数组 中 下 标 与 值 的 对 应 关系 


下 标 说 了 明 返回 值 示例 
"seconds" 秒 的 数字 表示 0~59 

"minutes" 分 钟 的 数字 表示 0~59 

"hours" 小 时 的 数字 表示 0 一 23 

"mday" 月 份 中 第 几 天 的 数字 表示 j=31 

"wday" 星期 中 第 几 天 的 数字 表示 0 (表示 星期 天 ) 一 6〈 表 示 星 期 六 ) 
"mon" 月 份 的 数字 表示 1~12 

"year" 4 位 数字 表示 的 完整 年 份 如 1999 或 2003 

"yday" -年 中 第 几 天 的 数字 表示 0 一 365 

"weekday" 星期 几 的 完整 文本 表示 Sunday 一 Saturday 
"month" 月 份 的 完整 文本 表示 January 一 December 

0 该 时 间 的 UNIX 时 间 戳 整数 


下 面 通过 一 个 实例 来 全 面 展示 getdateO 函 数 的 强大 功能 。 
【 例 3.29】 


<html> 

<head> 

<title>getdate0 函 数 获取 详细 的 时 间 信息 </tile> 
</head> 

<body> 

<?php 

/首先 假设 一 个 时 间 

$dt= "2010-10-0108:00:00"; 

echo "时 间 : ".$dt."<br>"; 

/将 此 时 间 格 式 化 为 UNIX 时 间 戳 

$tm= strtotime($dt); 

echo "此 时 间 的 UNIX 时 间 截 :".$tm."<br>"; 

// 获 取 该 时 间 的 详细 信息 

$arr = getdate($tm); \ 171/ 
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// 输 出 详细 信息 
echo " 秒 : ".$ar["seconds"]."<br>"; 
echo "分 : ".$arr["minutes"]."<br>"; 
echo "时 : ".$ar["hours"]."<br>"; 
echo "日 : ".$arr["mday"]."<br>"; 
"月 : ".$ar["mon"].".$ar["month"]."<br>": 
echo "年 : ".$ar["year"]."<br>"; 
echo "星期 :".$arr["wday"]."/".$arr["weekday"]."<br>"; 
echo "该 日 期 是 该 年 中 的 第 ".$ar["yday"]." 天 <br>"; 


运行 结果 如 图 3.19 所 示 。 


getdate() 函数 获取 详细 的 时 间 信 息 - Window. - 
G+-E leeuwsu: 国 [本 区 ] | 二 
富 收藏 天 。 | 逢 cetdate 0 函数 区 职 详细 9 时 间 信息 


时 间 ，2010-10-01 08:00:00 
和 1285920000 
0 


:1 

: 10/0ctober 
1 2010 
星期 ，5/Friday 

该 日 期 是 该 年 中 的 第 273 天 


图 3.19 ”getdate0 函 数 获取 详细 的 时 间 信 息 

本 程序 中 ， 第 8 行 设置 了 一 个 时 间 ， 第 11 行将 此 时 间 格 式 化 成 UNIX 时 间 戳 ， 第 14 
行将 此 时 间 戳 用 getdate0 函 数 获取 详细 时 间 信 息 ， 然 后 在 第 16 一 23 行 分 别 输出 时 间 信 息 。 

本 程序 中 假定 日 期 为 2010-10-0108:00:00， 实 际 上 可 以 直接 用 语句 $arr = getdate(); 来 获 
得 当前 时 间 的 详细 信息 。 这 时 输出 的 时 间 信 息 就 是 当前 程序 执行 时 的 时 间 信息 。 感 兴趣 的 
读者 可 以 自行 测试 。 

(2) date0 函 数 。 

date0 函 数 用 来 将 一 个 UNIX 时 间 戳 格式 化 成 指定 的 时 间 / 日 期 格式 。getdateO 函 数 可 以 
获取 详细 的 时 间 信 息 , 但 是 很 多 时 候 并 不 需要 取得 如 此 具体 的 时 间 信 息 , 而 是 将 一 个 UNIX 
时 间 惟 所 代表 的 时 间 按 照 某 种 容易 识 读 的 格式 输出 。 这 就 需要 用 到 date0 函 数 。 该 函数 的 使 
用 格式 如 下 : 


string date ( string format [, int timestamp] ) 


该 函数 直接 返回 一 个 字符 串 。 这 个 字符 串 就 是 一 个 指定 格式 的 日 期 和 时 间 。 参 数 format 
是 一 个 字符 串 ， 用 来 指定 输出 的 时 间 的 格式 。 可 选 参数 timestamp 是 要 处 理 的 时 间 的 UNIX 
时 间 戳 。 如 果 参 数 为 空 ， 那 么 默认 值 为 当前 时 间 的 UNIX 时 间 戳 。 

本 函数 的 重点 是 学 习 如 何 使 用 format 参数 。format 参数 必须 由 指定 的 字符 构成 ， 不 同 


的 字符 代表 不 同 的 特殊 含义 ， 如 表 3.5 所 示 。 
/ 
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表 3.5 format 参数 一 览 


format 参数 说 明 返回 值 例子 
d 月 份 中 的 第 儿 天 ， 有 前 导 0 的 两 位 数字 01~31 
D 星期 中 的 第 几 天 ， 文 本 表示 ，3 个 字母 Mon 一 Sun 
1 月 份 中 的 第 几 天 ， 没 有 前 导 0 1~31 
| 星期 几 ， 完 整 的 文本 格式 Sunday 一 Saturday 
十 ce (PHP 1 (表示 星期 一) ~7 (表示 星期 天 ) 
Ww 星期 中 的 第 几 天 ， 数 字 表示 0 (表示 星期 天 ) 一 6 (表示 星期 六 ) 
z 年 份 中 的 第 几 天 0 一 366 
ISO-8601 格式 年 份 中 的 第 几 周 ， 每 周 从 星期 一 开 
始 (PHP 4.1.0 新 加 的 参数 ) 名作 (年 的 生性 同 
F 月 份 ， 完 整 的 文本 格式 January 到 December 
m 数字 表示 的 月 份 ， 有 前 导 0 01 一 12 
M 3 个 字母 缩写 表示 的 月 份 Jan 一 Dec 
n 数字 表示 的 月 份 ， 没有 前 导 0 1~12 
t 给 定 月 份 所 应 有 的 天 数 28~31 
下 是 否 为 头 年 如 果 是 闲 年 为 1， 和 否则 为 0 


Y 4 位 数字 完整 表示 的 年 份 如 1999 或 2003 
2 位 数字 表示 的 年 份 如 99 或 03 
a 小 写 的 上 午 和 下 午 值 am 或 pm 
A 大 写 的 上 午 和 下 午 值 AM 或 PM 
B Swatch Internet 标准 时 000 一 999 
g 小 时 ，12 小 时 格式 ， 没 有 前 导 0 1~12 
G 小 时 ，24 小 时 格式 ， 没 有 前 导 0 0~23 
h 小 时 ，12 小 时 格式 ， 有 前 导 0 01~12 
H 小 时 ，24 小 时 格式 ， 有 前 导 0 00 一 23 
i 有 前 导 0 的 分 钟 数 00 一 59 
秒 数 ， 有 前 导 0 00 一 59 
e 时 区 标识 (PHP 5.1.0 中 的 新 参数 ) 如 UTC、GMT、Atlantic/Azores 
I 是 否 为 夏令 时 如 果 是 夏令 时 为 1， 否则 为 0 
O 与 格林 威 治 时 间 相 差 的 小 时 数 如 +0200 
时 本 机 所 在 的 时 区 如 EST、MDT 等 


表 3.5 中 列 出 了 绝 大 部 分 format 参数 字符 ， 个 别 极为 不 常用 的 没有 列 出 。 通 过 表 3.5 
已 经 看 出 format 参数 字符 数量 众多 ， 涉 及 方方面面 。date0 函 数 可 以 完成 的 功能 极为 丰富 。 

下 面 通过 一 个 实例 来 看 一 下 如 何 使 用 format 字符 。 

【 例 3.30】 


<html> 


<head> \ 77 
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<title> 用 格式 化 字符 串 输出 时 间 信 息 </tide> 

</head> 

<body> 

<?php 

/设置 一 个 时 间 〈 如 采用 当前 时 间 可 用 tme0) 

S$tm = strtotime("2006-09-09 10:30:40"); 

echo "初始 化 设置 的 时 间 为 : 2006-09-09 10:30:40<br>"; 
// 使 用 不 同 的 格式 化 字符 串 测试 输出 效果 

echo date("Y-M-D H:IS A",$tm)."<br>"; 

echo date("y-m-d h:i:s a",$tm)."<br>"; 

echo date("Y 年 m 月 d 日 由理 点 i 分 s 秒 ",$tm)."<br>"; 
echo date("F,d,Y 1",$tm)."<br>"; 

echo date("Y-M-D H:I:S",$tm)."<br>"; 

echo date("Y-M-D H:I:S",$tm)."<br>"; 

echo date(" 所 在 时 区 : T， 与 格林 威 治 时 间 相 差 : O 小 时 ",$tm)."<br>"; 
/输出 详细 信息 


到 行 结果 如 图 3.20 所 示 。 


a s 
GO- locdhost/; 半 | 刀 |X| 局 
会 收 庆 天 | 忽 用 格式 化 字符 囊 输出 时 间 信息 


初始 化 设置 的 时 间 为 ，2006-09-09 10:30:40 
2006-Sep-Sat 10:0:th AL 

06-09-09 10:30:40 am 

2006 年 09 月 09 日 [ee 10 点 30 分 40 秒 
September, 09, 2006 Saturday 

2006-Sep-Sat 10:0: 站 

2006-Sep-Sat 10:0 

所 在 时 区 ，UTC， 呈 竹 林 厂 治 时 间 相关 ， +0000 小 时 


图 3.20 用 格式 化 字符 串 输出 时 间 信 息 


通过 上 面 程序 可 以 看 出 ， 格 式 化 字符 串 的 使 用 非常 灵活 。 只 要 在 字符 串 中 包含 相关 字 
符 ，date0) 函 数 就 能 把 这 些 字符 替换 成 指定 的 时 间 / 日 期 信息 ,可 以 利用 该 函数 输出 需要 的 时 
间 / 日 期 格式 。 

程序 的 最 后 一 条 输出 用 的 是 格式 字符 T 和 O 来 输出 运行 本 程序 的 服务 器 所 处 的 时 区 以 
及 本 时 区 和 格林 威 治标 准时 间 相 差 的 小 时 数 。 程 序 输出 时 区 为 UTC， 相 差 时 间 为 0 小 时 。 
这 虽然 与 世界 标准 时 区 和 时 间 相 符 ， 但 是 并 不 是 本 地 时 间 。 如 北京 时 间 要 比 格林 威 治 时 间 
晚 8 个 小 时 ， 因 此 在 取得 的 本 地 时 间 基 础 上 再 增加 8 个 小 时 才 是 北京 时 间 。 增 加 8 个 小 时 
的 方法 很 简单 ， 在 已 经 取得 的 当前 时 间 的 UNIX 时 间 戳 上 加 8x60x60 即 是 8 小 时 之 后 的 时 
间 戳 。 如 果 读 者 在 编写 程序 时 发 现 程序 获得 的 时 间 与 北京 时 间 不 符 ， 应 该 考虑 是 否 为 时 区 
问题 ， 对 取得 的 时 间 进 行 相 应 处 理 即 可 。 

PHP 的 时 间 / 日 期 函数 很 常用 ， 但 并 不 复杂 。 一 般 只 需要 掌握 UNIX 时 间 戳 的 获得 和 操 
作 方 法 ， 以 及 格式 化 字符 的 使 用 方法 ， 即 可 轻松 掌握 PHP 中 时 间 / 日 期 的 处 理 。 


NT 
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3.2.4 数学 函数 


编程 中 少不了 要 进行 数据 计算 操作 。 除 了 基本 的 加 、 减 、 乘 、 除 等 运算 以 外 ， 还 有 求 正 
弦 值 、 余 弦 值 、 绝 对 值 、 对 数值 、 取 整 、 取 余 、 进 制 转换 以 及 生成 随机 数 等 一 系列 操作 ， 这 
些 操作 都 可 以 通过 简单 的 函数 调用 来 实现 。 表 3.6 列 出 了 PHP 中 常用 的 数学 函数 及 其 功能 。 


表 3.6 PHP 中 常用 的 数学 函数 


abs 求 绝对 值 is finite 判断 是 否 为 有 限 值 
放 


功 
acos 求 反 余弦 判断 是 否 为 无 限 值 


acosh 求 反 双 曲 余 判断 是 否 为 合法 数值 
asin 求 反正 弦 lcg value 组 合 线性 同 余 发 生 器 
asinh | 求 反 双 昌 正 继 。 | 1og。 | 以 10 为 底 的 对 数 
atan2 | 两 个 参数 的 反正 切 | log | 自然 对 数 

atan 找 出 最 大 值 


ax 


atanh | 求 反 双 曲 正切 | min | 找 由 最 小 值 


base_convert | 在 任意 进 制 之 间 转 换 数字 显示 随机 数 的 最 大 可 能 值 
bindec - 进 制 转换 为 十 进 制 | mt rand 。 | 生成 更 好 的 随机 数 
ceil 进 一 法 取 整 播 下 一 个 更 好 的 随机 数 发 生 器 种 子 


cos | 求 作 弦 [octaee | 八进制 转换 为 十 进 制 
cosh 求 双 曲 余弦 [pi | 得 到 圆周 率 值 


decbin 十 进 制 转换 为 二 进 制 指数 表达 式 

dechex 十 进 制 转换 为 十 六 进 制 将 弧度 数 转换 为 相应 的 角度 数 
decoct 产生 一 个 随机 整数 

deg2rad 对 浮 点 数 进行 四 舍 五 入 


exp 计算 e (自然 对 数 的 底 ) 的 指数 | sn | 求 正弦 
floor 舍 去 法 取 整 | sinh ”| 求 双 曲 正弦 


fmod 返回 除法 的 浮 点 数 余数 sqrt 求 平方 根 
getrandmax | 显示 随机 数 最 大 的 可 能 值 srand 播 下 随机 数 发 生 器 种 子 
tanh 求 双 曲 正切 hexdec 十 六 进 制 转换 为 十 进 制 


hypot 计算 直角 三 角形 的 斜 边 长 度 


本 类 函数 虽然 数目 众多 ， 但 是 使 用 方法 较为 简单 ， 函 数 功能 对 照 表 3.6 便 可 一 目 了 然 。 
下 面 用 一 个 实例 来 说 明 几 个 常用 数学 函数 的 使 用 方法 。 

首先 产生 一 个 大 于 等 于 50 小 于 等 于 150 的 随机 数 ， 把 这 个 数字 作为 一 个 圆 的 面积 ， 然 
后 根据 这 个 面积 算出 圆 的 半径 ， 并 将 得 到 的 半径 用 不 同 的 方法 取 整 。 

【 例 3.31】 


<html> 


<head> \ 177 
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<title> 数 学 函数 使 用 举例 </title> 


</head> 

<body> 

<?php 

$s = rand(50,150); 

$pi-piO; 

S$r=sqrt($s/$pi); 

$qzl=round($7); // 四 舍 五 入 取 整 
$qz2=ceil($7): // 进 一 法 取 整 
$qz3=floor($D; // 舍 去 法 取 整 


echo "随机 产生 的 圆 的 面积 为 :".$s."<br>"; 

echo "通过 除法 和 开 方 计算 出 的 圆 的 半径 为 : ".$r"<br>"; 
echo "四 舍 五 入 取 整 后 :".$qz1."<br>"; 

echo " 进 一 法 取 整 后 :".$qz2."<br>"; 

echo " 舍 去 法 取 整 后 : ".$qz3."<br>"; 

?> 

</body> 

</html> 


程序 用 到 了 6 个 数学 函数 ， 分 别 用 来 产生 一 定 范围 内 的 随机 数 、 返 回 圆周 率 〈 精 确 到 
小 数 点 后 14 位 )、 开 方 以 及 取 整 等 。 程 序 本 身 比 较 简单 ， 不 再 详细 讲解 。 

由 于 圆 的 面积 是 随机 产生 的 ， 所 以 每 次 刷新 页 面 都 会 重新 产生 一 组 数据 。 读 者 可 以 自 
行 试验 ， 通 过 不 同 的 数据 来 分 析 程 序 中 函数 的 作用 。 

数学 函数 的 使 用 都 较为 简单 ， 本 书 限于 篇 幅 不 再 一 一 介绍 ， 请 读者 参考 PHP 手册 ， 测 
试 其 他 函数 的 使 用 方法 。 


3.2.5 图像 处 理 函 数 


PHP 提供 了 一 系列 函数 来 实现 在 网 站 编程 中 对 图 像 的 编辑 。 虽 然 使 用 这 些 函 数 能 够 实 
现 的 功能 十 分 有 限 ， 无 法 和 功能 强大 的 专业 图 形 图 像 软 件 相 比 ， 但 是 在 很 多 需要 动态 生成 
图 像 、 自 动 批量 处 理 图 像 等 方面 ， 能 给 PHP 网 站 开发 者 带 来 巨大 帮助 。 其 中 最 为 典型 的 应 
用 有 随机 图 形 验 证 码 、 图 片 水 印 、 数 据 统 计 中 人 饼 状 图 、 柱 状 图 的 生成 等 。 表 3.7 中 列 出 了 
PHP 的 常用 的 图 像 处 理 函 数 。 


表 3.7 PHP 中 常用 的 图 像 处 理 函数 


函 数 名 功 能 

d_info 取得 当前 安装 的 GD 库 的 信息 
getimagesize 取得 图 像 大 小 
image type _to_extension 取得 图 像 类 型 的 文件 后 绥 
imagearc 画 椭圆 弧 
imagechar 水 平地 画 一 个 字符 
imagecharup 垂直 地 画 一 个 字符 
imagecopy, 复制 图 像 的 一 部 分 

\y/ imagecopymerge 复制 并 合并 图 像 的 一 部 分 
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函 数 名 


imagecopyresized 


功 


复制 部 分 图 像 并 调整 大 小 


imagecreatefromgd2 从 GD2 文件 或 URL 新 建 一 图 像 
imagecreatefromgd 从 GD 文件 或 URL 新 建 一 图 像 
imagecreatefromgif 从 GIF 文件 或 URL 新 建 一 图 像 
imagecreatefromjpeg 从 JPEG 文件 或 URL 新建 一 图 像 
imagecreatefrompng 从 PNG 文件 或 URL 新 建 一 图 像 
imagecreatefromstring 从 字符 串 中 的 图 像 流 新 建 一 图 像 
imagecreatetruecolor 新 建 一 个 真 彩色 图 像 
imagedashedline 画 一 虚线 

imagedestro 销毁 一 图 像 

imageellipse 画 一 个 椭圆 

imagefill 区 域 填充 

imagefilledarc 画 一 椭圆 弧 并 填充 
imagefilledellipse 画 一 椭圆 并 填充 


imagefilledpolygon 
imasgefilledrectangle 
imageed2 

imageed 

imageegif 
imageistruecolor 
imageipeg 

imageline 
imageloadfont 
imagepalettecop 
imagepng 
imagepolygon 


imagepstext 


画 一 多 边 形 并 填充 
画 一 矩形 并 填充 


将 GD2 图 像 输出 到 浏览 器 或 文件 
将 GD 图 像 输出 到 浏览 器 或 文件 
以 GIF 格式 将 图 像 输出 到 浏览 器 或 文件 


检查 图 像 是 否 为 真 彩色 图 像 


以 JPEG 格式 将 图 像 输出 到 浏览 器 或 文件 


画 一 条 线段 
载 入 一 新 字体 


将 调 色 板 从 一 幅 图 像 复 制 到 另 一 幅 
以 PNG 格式 将 图 像 输出 到 浏览 器 或 文件 


画 一 个 多 边 形 


用 PostScript Typel 字体 把 字符 串 画 在 图 像 上 


imagerectangle 画 一 个 矩形 
imagerotate 用 给 定 角度 旋转 图 像 
imagesetbrush 设 定 画 线 用 的 画笔 图 像 
imagesetpixel 画 一 个 单一 像素 
imagesetstyle 设 定 画 线 的 风格 
imagesetthickness 设 定 画 线 的 宽度 
imagesettile 设 定 用 于 填充 的 贴图 
imagestring 水 平地 画 一 行 串 
imagestringup 垂直 地 画 一 行 字符 串 
imagesx 取得 图 像 宽度 
imagesy 取得 图 像 高 度 


-高 等 职 


一 一 项目 3 PHP 中 函数 的 学 习 国 


PHP 5 提供 的 图 像 处 理 函 数 有 100 多 个 ， 表 3.7 中 仅 列 出 了 部 分 常用 函数 。 

PHP 的 图 像 处 理 函 数 都 封装 在 一 个 函数 库 中 ， 这 就 是 GD 库 。 要 使 用 GD 库 中 的 函数 
来 进行 图 像 处 理 ， 必 须 保 证 安装 了 GD 库 。 在 PHP 官方 的 标准 发 行 版 本 中 ， 都 包含 了 GD 
库 。 如 本 书 介绍 的 PHP 5$, 其 GD 库存 放 在 PHP 安装 目录 下 的 ext 子 目录 下 , 名 为 php_gd2.d]]。 

但 并 不 是 php_gd2.dll 库 文件 存在 ， 就 可 以 使 用 这 些 函 数 了 。 在 默认 的 php.ini 设置 中 ， 
该 库 并 不 自动 载 入 。 所 以 ， 需 要 首先 打开 库 的 自动 载 入 功能 ， 这 样 库 中 的 函数 就 像 PHP 标准 
函数 一 样 可 以 直接 在 程序 中 使 用 了 。 打 开 的 方法 很 简单 ， 用 记事 本 打开 php.ini 配置 文件 , 利 
用 查找 功能 找到 代码 行 “;extension=php_gd2.dll”， 将 最 前 面 的 分 号 去 掉 ， 然 后 保存 ， 重 新 启 
动 IS (Apache)， 这 时 GD 库 就 被 自动 加 载 。 
本 部 分 函数 数量 较 多 ， 而 且 具 体 使 用 方法 较为 复杂 ， 感 兴趣 的 读者 可 以 参考 PHP 手册 
进行 深入 学 习 。 

1，PHP 基本 绘 


下 面 通过 一 个 实例 来 学 习 用 PHP 进行 基本 绘图 的 方法 。 
【 例 3.32】 


<2php 

// 程 序 3.32.php: 图 像 处 理 函 数 使 用 举例 
header("Content-type: image/png"); 

$im = @imagecreate(200, 100) or die(" 无 法 创建 图 像 流 "); 
@imagecolorallocate($im, 240, 150, 255); 

$t_colorl= imagecolorallocate($im, 0, 0, 0); 

$t_color2= imagecolorallocate($im.,100,100,100); 
imagestring($im, 5, 8, 10, "PHP IS EASY!", $t_colorl); 
imagestringup($im,5,8,90,"Hello WORLD!",$t_color2); 
imageellipse($im,65,65,55,55,$t_color]1); 
imageellipse($im,65,65,55,55,$t_color]); 
imagefilledrectangle($im,110,95,160,30,$t_color2); 
imagepng($im):; 

imagedestroy($im); 

?> 


运行 结果 如 图 3.21 所 示 。 


图 3.21 创建 图 像 图 示 
三 在 程序 3.32php 的 第 3 行 指定 了 图 像 的 类 型 , 即 PNG 图 像 , 这 样 虽 然 是 一 个 PHP 程序 ， 
/ 
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但 是 其 作用 是 动态 生成 一 张 图 像 ， 因 此 几乎 等 同 于 一 张 图 像 。 在 本 程序 中 ， 普 通 的 输出 语 
句 如 echo 等 都 是 无 效 的 ， 这 一 点 读者 应 当 注 意 。 

第 4 行 用 imagecreateO) 函 数 创建 一 幅 新 图 像 ， 两 个 参数 为 图 像 的 宽度 和 高 度 ， 单 位 是 
像素 。 此 函数 返回 此 图 像 的 数据 流 ， 存 放 于 $im 变量 中 。 

第 5 行 用 imagecolorallocate0 函 数 设置 了 图 像 的 背景 颜色 ，4 个 参数 分 别 表示 图 像 流 、 
及 色 值 、G 色 值 、B 色 值 。3 个 色 值 合并 即 产生 了 RGB 色 值 。 这 里 的 (240，150，255) 运 
行 之 后 显示 淡 紫 色 。 另 外 ，(0，0，0) 为 黑色 ，(255，255，255) 为 白色 ，(255，0，0) 
为 红色 等 。 关 于 RGB 颜色 的 详细 信息 读者 可 自行 查阅 有 关 资 料 。 

第 6 一 7 行 分 别 生 成 了 两 种 颜色 ， 存 在 于 不 同 的 变量 中 以 备 后 面 使 用 。 第 1 种 为 黑色 ， 
第 2 种 为 浅 灰 色 。 

第 8 行 用 imagestring0) 函 数 在 图 像 上 写 入 一 个 字符 串 ，6 个 参数 分 别 表 示 图 像 流 、 所 用 
字体 、 写 入 点 的 x 坐标 、 写 入 点 的 y 坐标 、 要 写 入 的 字符 串 、 字 符 串 颜色 。 其 中 有 两 点 值 
得 注意 : 第 一 点 是 函数 的 第 2 个 参数 取 值 范围 为 1 一 5， 分别 代表 不 同 大 小 和 是 否 加 粗 的 5 
种 字体 ， 读 者 可 以 试 着 修改 此 参数 来 观察 程序 运行 效果 ; 第 二 点 是 这 里 的 x，y 坐标 都 相对 
于 图 像 的 左上 角 ， 左 上 角 坐 标 为 《0，0)， 向 右 为 x 轴 ， 向 下 为 yY 轴 ， 单 位 都 是 像素 。 

第 9 行 用 imagestringup0 函 数 向 图 像 中 竖 向 写 入 一 个 字符 串 。 函 数 的 参数 含义 与 imagestringO) 
函数 相同 。 

第 10 行 用 imageellipse0 函 数 在 图 像 中 绘制 一 个 圆 ，6 个 参数 分 别 表示 图 像 流 、 圆 心 的 x 
坐标 、 圆 心 的 y 坐标 、 圆 的 x 方 向 半径 长 度 、 圆 的 y 方 向 半径 长 度 和 绘图 所 用 颜色 。 在 本 
例 中 ， 绘 制 了 一 个 圆心 在 (65，65)、 半 径 为 55 的 正 圆 。 如 果 要 绘制 一 个 椭圆 ， 只 需要 确 
定 圆心 位 置 ， 然 后 分 别 设置 x 方向 半径 和 y 轴 方 向 半径 即 可 。 当 这 两 个 半径 相等 时 是 一 个 
圆 ， 不 相等 时 是 一 个 椭圆 。 

第 11 行 用 imagefilledrectangle0 函 数 绘制 一 个 矩形 , 并 对 矩形 进行 颜色 填充 。6 个 参数 分 
别 表 示 图 像 流 、 和 矩形 左上 角 x 坐标 、 和 矩形 左上 角 y 坐标 、 拢 形 右 下 角 x 坐标 、 和 矩形 右 下 角 
y 坐标 和 填充 颜色 。 也 就 是 说 ， 只 要 提供 矩形 的 左上 角 和 右 下 角 坐 标 ， 即 可 绘制 此 算 形 。 

第 12 行 用 imagepng0 函 数 将 此 图 像 流 输出 为 一 张 PNG 格式 的 图 片 ， 也 就 是 在 浏览 
中 看 到 的 图 片 。 

第 13 行销 毁 了 这 个 图 像 流 。 

在 本 例 中 除了 PNG 格式 ， 还 可 以 把 图 像 输出 为 PEG、GIF 等 常用 的 格式 ， 只 需要 更 
改 一 下 程序 中 第 3 行 所 指定 的 图 像 类 型 即 可 。 

2. 网 站 图 形 验证 码 的 制作 

图 形 验证 码 程序 是 当前 Web 开发 中 常用 的 程序 。 利 用 了 PHP 的 图 像 处 理 函 数 , 结合 前 
面 学 习 的 Session 函数 以 及 表单 数据 提交 技术 ， 可 以 写 出 一 个 完整 的 图 形 验证 码 程序 。 

验证 码 在 网 站 中 的 作用 一 般 是 防止 恶意 “灌水 ” 也 就 是 防止 恶意 发 布 垃圾 信息 。 如 果 
没有 验证 码 ， 攻 击 者 可 以 利用 辅助 软件 实现 自动 提交 、 自 动 注册 等 。 由 于 辅助 软件 执行 的 
效率 高 、 速 度 快 且 可 以 连续 工作 ， 因 此 常用 来 攻击 某 个 网 站 ， 制 造 大 量 垃 圾 数据 ， 严 重 影 
响 网 站 正常 运行 。 ee 
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采用 验证 码 之 后 ， 由 于 验证 码 每 次 都 不 一 样 ， 只 有 输入 正确 的 验证 码 才能 提交 信息 ， 这 
样 辅助 软件 就 无 法 随意 向 服务 器 提交 信息 。 因 此 ， 验 证 码 的 设计 也 有 一 些 原则 ， 如 验证 码 的 
生成 是 随机 的 ， 无 规律 可 循 。 另 外 ， 有 的 辅助 软件 有 文字 识别 功能 ， 能 够 从 图 片 中 辨析 出 文 
字 ， 因 此 验证 码 中 的 数字 可 以 采用 随机 的 颜色 和 角度 ， 使 其 不 易 辨 认 。 总 之 ， 最 理想 的 验证 
码 应 该 是 人 的 肉眼 可 以 很 容易 地 辨认 出 来 ， 但 是 用 软件 识别 就 极为 困难 。 

鉴于 此 ， 在 设计 验证 码 程序 时 ， 不 是 简单 地 创建 一 幅 图 片 ， 然 后 随机 生成 几 个 数字 写 
上 去 , 而 是 要 再 加 入 一 些 干扰 。 如 可 以 用 PHP 提供 的 图 像 处 理 函数 在 图 像 上 加 入 一 些 密 密 
麻 麻 的 像素 点 ， 然 后 随机 绘制 两 条 虚线 ， 再 将 几 个 数字 的 位 置 打 乱 。 这 样 ， 机 器 识别 就 会 
变 得 十 分 困难 。 

下 面 用 3 个 实例 来 介绍 网 站 图 形 验 证 码 的 制作 和 使 用 ， 将 用 到 以 下 3 个 文件 。 

回 3.showing.php: 生成 验证 码 ， 将 验证 码 写 入 图 片 ， 并 输出 图 片 。 

回 3.login.html: 调用 showing.php， 将 用 户 输入 的 验证 码 提交 到 check.php 进行 验证 。 

回 ”3.checkphp: 用 来 验证 用 户 输 入 的 验证 码 是 否 正确 。 

下 面 就 来 看 一 下 具体 的 代码 。 

【 例 3.33】 


<2php 
/文件 3.showingphp: 生成 验证 码 图 片 并 输出 
/随机 生成 一 个 4 位 数 的 数字 验证 码 
$num=""; 
for($i=0;$1<4;$1++){ 
$num .= rand(0,9); 
} 
//4 位 验证 码 也 可 以 用 rand(1000,9999) 直 接生 成 
/将 生成 的 验证 码 写 入 Session， 备 验证 页 面 使 用 
session start(); 
$_SESSION["Checknum"] = $num; 
// 创 建 图 片 ， 定 义 颜色 值 
header("Content-type: image/PNG"); 
srand((double)microtimeO*1000000); 
S$im = imagecreate(60,20); 
S$black = ImageColorAllocate($im, 0.0.0); 
$egray = ImageColorAllocate($im, 200,200,200); 
imagefill($im,0.,0,$gray): 
// 随 机 绘制 两 条 虚线 ， 起 干扰 作用 
S$style = array($black, $black, $black, $black, $black, $gray, $gray, $eray, $eray, $egra y): 
imagesetstyle($im, $style):; 
$yl1=rand(0,20); 
$y2=rand(0,20); 
$y3=rand(0,20); 
$y4=rand(0,20); 
imageline($im, 0, $y1, 60, $y3, IMG_COLOR_STYLED); 
imageline($im, 0, $y2, 60, $y4, IMG_COLOR_STYLED): 
// 在 画布 上 随机 生成 大 量 黑 点 ， 起 干扰 作用 
\\ ， for(S$i=0:$i<80:$i+H){ 
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imagesetpixel($im, rand(0,60), rand(0,20), $black); 


上 

// 将 4 个 数字 随机 显示 在 画布 上 ， 字 符 的 水 平 间 距 和 位 置 都 按 一 定 波动 范围 随机 生成 
$strx=rand(3,8); 

for($i=0:$i<4:$i+H){ 

$strpos=rand(1,6); 

imagestring($im,5,$strx, $strpos, substr($num,$i,1), $black); 
$strx+=rand(8,12); 

} 

ImagePNG($in); 

ImageDestroy($im); 

和 


运行 结果 如 图 3.22 所 示 。 
http://localhost/3.33.php Windows I 


GO Br 


富 收藏 天 镍 http://localhost/3.33.php 


图 3.22 创建 验证 码 图 示 
程序 中 的 重要 代码 都 已 经 做 了 注释 ， 在 此 不 再 详细 讲解 。 本 程序 运行 后 可 以 在 浏览 器 
中 生成 一 幅 带 有 验证 码 的 图 片 ， 每 次 刷新 程序 都 会 生成 一 个 新 验证 码 。 
【 例 3.34】 


<!-- 文 件 3Jogin html: 图 形 验 证 码 程序 --> 
<html> 

<head> 

<title> 图 形 验证 人 码 程序 </title> 

</head> 

<body> 

<form action="3.check.php" method="post"> 
<img src="3.showing.php"><br> 

请 输入 验证 码 : <input type="text" name="passcode"> 
<input type=submit value=" 确 定 "> 

</form> 

</body> 

</html> 


本 程序 是 一 段 纯 HTML 代码 , 无 须 多 做 解释 。 唯一 值得 注意 的 是 , 在 调用 这 个 图 片 时 ， 
采用 <img src="3.showing php"> 的 方式 。 因 为 验证 码 图 片 本 身 是 一 幅 图 片 ， 所 以 使 用 <img> 
标签 来 引用 。 而 这 张 图 片 又 是 用 PHP 程序 生成 的 ， 因 此 直接 用 src=3.showing.php 来 调用 。 

【 例 3.35】 
<2?php 
/文件 3.check.php: 验证 用 户 输入 的 验证 码 是 否 正确 


session start(); 


NI/ 
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S$passcode=$_SESSION["Checknum"]; 
$usercode=$ POST["passcode"]; 
if($passcode 一 $usercode){ 

echo "验证 码 正确 ! 验证 通过 !"; 
}else{ 

echo "验证 码 输入 错误 ! 验证 失败 ! "; 
和 


?> 


程序 第 3 行 是 将 Session 中 存储 的 正确 的 验证 码 读 取出 来 .第 4 行将 用 户 输入 的 验证 码 
接收 过 来 ， 然 后 进行 比较 ， 如 果 相等 ， 则 说 明 用 户 输入 的 验证 码 正确 ， 否 则 不 正确 。 
3.， 图片 水 印 的 制作 


在 PHP 中 ,不 仅 可 以 直接 创建 一 个 图 像 流 来 绘制 图 形 ， 还 可 以 将 一 张 已 有 的 图 片 作为 
图 像 流 读 入 ， 然 后 在 此 基础 上 对 图 像 进行 处 理 。 这 一 功能 常用 来 制作 图 像 水 印 。 所 谓 图 像 
水 印 ， 就 是 在 图 像 上 标记 一 些 特殊 的 图 形 或 符号 ， 用 来 作为 图 像 所 有 者 的 标志 ， 防 止 图 像 
被 资 用。 下面 就 来 看 一 个 这 样 的 例子 。 

例 3.36 使 用 一 张 原始 图 片 pjpg， 用 PHP 将 此 图 片 进行 处 理 ， 在 图 片 表面 按 一 定 规律 
加 上 文字 标签 ， 产 生 水 印 效果 ， 使 之 不 能 被 直接 盗用 。 

【 例 3.36】 


<2php 

/文件 3syphp: 为 图 片 加 水 印 
header("Content-type: image/jpeg"); 

S$im = imagecreatefromjpeg("p.jpe"); 

Swhite = imagecolorallocate($im,255,255,255); 
$width=imagesx($im); 

S$height=imagesy($im); 

$x=0; 

$y=0; 

while($x<$width && $y<$height){ 
imagestring($im,2, $x,$y,"http://www.xxx.com", $white):; 
$x+=20; 

$y+=20; 

} 

imagejpeg($im); 

imagedestroy($im); 

?> 


本 程序 第 3 行 设 定 本 页 面 输出 类 型 为 JPEG 图 像 。 第 4 行 用 imagecreateformjpeg() 函 数 
打开 了 一 张 图 片 pjpg， 并 返回 此 图 片 的 数据 流 。 第 5 行 定义 了 一 个 颜色 (白色 )。 第 6 一 7 
行 用 imagesx0 和 imagesy0 函 数 取 得 图 片 pjpg 的 原始 尺寸 .第 8 一 9 行 定义 了 用 于 控制 文字 
添加 位 置 的 两 个 变量 。 第 10 一 14 行 用 循环 向 图 片 中 添加 多 行文 字 ， 用 $x 和 $y 两 个 变量 控 
制 位 置 和 循环 次 数 。 第 15 行 输出 此 图 片 。 第 16 行销 毁 数据 流 。 
读者 可 以 自行 在 PHP 环境 中 运行 并 查看 效果 。 处 理 后 的 图 片上 加 入 了 文字 标记 ， 这 就 
\y/ 
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基本 达到 了 处 理 意图 。 但 是 同时 也 可 以 看 


理 中 最 应 考虑 的 。 


因此 ， 水 印 如 何 加 ， 加 在 什么 位 置 ， 既 能 起 到 水 印 的 作用 ， 又 不 严 寻 


0 入 观赏 性 有 所 下 
EE 影响 美观 ， 才 是 


上 ， 处 理 后 的 图 片 由 于 文字 的 力 


PHP 的 图 像 处 理 函 数 就 介绍 至 此 ， 和 希望 读 者 对 其 有 一 个 基本 的 了 解 ， 为 以 后 的 深入 学 


习 打 下 基础 。 
3.2.6 文件 系统 函数 


在 网 络 编程 中 要 用 到 的 文件 操作 大 致 可 以 分 为 两 大 类 : 普通 文件 的 操作 和 数据 库 文件 
的 操作 。 在 普通 文件 的 操作 中 ， 对 记事 本 文件 的 操作 最 为 简单 ， 下 面 就 来 探讨 一 下 PHP 对 
文件 〈 以 记事 本 为 例 ) 的 操作 。PHP 中 提供 了 一 些 文件 操作 的 函数 ， 常 用 函数 如 表 3.8 


表 3.8 PHP 中 常用 的 文件 操作 函数 


所 示 。 

函 数 名 功 能 
basename 返回 路 径 中 的 文件 名 部 分 
chmod 改变 文件 模式 
clearstatcache ”| 清除 文件 状态 缓存 
delete 参见 unlink0) 或 unsetO 


disk free space | 返回 目录 中 的 可 用 空间 


功 
测试 文件 指针 


从 文件 指针 中 读 取 字 符 
fgets 从 文件 指针 中 读 取 一 行 
检查 文件 或 目录 是 否 存在 
file put contents | 将 一 个 字符 串 写 入 文件 


能 
到 了 文件 结束 的 


是. 下 
是 奋 


diskfreespace 。 |disk_free_space0 的 别名 取得 文件 的 上 次 访问 时 间 
filegroup 取得 文件 的 组 flock 轻便 的 咨询 文件 锁定 
filemtime 取得 文件 修改 时 间 fopen | 打开 文件 或 者 URL 
fileperms 取得 文件 的 权限 将 行 格式 化 为 CSV 并 写 入 文件 指针 
filetype 取得 文件 类 型 fread 读 取 文 件 (可 安全 用 于 二 进 制 文件 ) 
fhmatch 用 模式 匹配 文件 名 在 文件 指针 中 定位 
passthru 输出 文件 指针 处 的 所 有 剩余 数据 |ael 。 ”| 返回 文件 指针 读 / 写 的 位 置 
puts fwrite0 的 别名 fwrite 写 入 文件 (可 安全 用 于 二 进 制 文件 ) 
fscanf 从 文件 中 格式 化 输入 is dir 判断 给 定 文件 名 是 否 为 一 个 目录 
通过 已 打开 的 文件 指针 取得 文件 | 判断 给 定 文件 名 是 否 为 一 个 正常 的 
fstat i is_file 
信息 四 文件 
ftruncate 将 文件 截断 到 给 定 的 长 度 is readable 判断 给 定 文件 名 是 否 可 读 
seb 寻找 与 模式 匹配 的 文件 路 径 。。 is_uploaded fine Fro eS 
is_executable “| 判断 给 定 文件 名 是 否 可 执行 is_writeable is_writable0 的 别名 
i ee i 获取 一 个 连接 的 信息 
chgrp 改变 文件 所 属 的 组 新 建 目录 
chown 改变 文件 的 所 有 者 解析 一 个 配置 文件 


% 
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续 表 
画 数 名 功 能 功 能 
i 复制 文件 关闭 进程 文件 指针 
dirname 返回 路 径 中 的 目录 部 分 readfile 输出 一 个 文件 
disk total space | 返回 一 个 目录 的 磁盘 总 大 小 realpath 返回 规范 化 的 绝对 路 径 名 
felose 关闭 一 个 已 打开 的 文件 指针 rewind 倒 回 文件 指针 的 位 置 
fflush 将 缓冲 内 容 输出 到 文件 set file buffer stream set write buffer0 的 别名 
en A - 行 并 解析 a 
re 从 文件 指针 中 恋 取 一 生养 过 并 ee 
HTML 标记 
file_ get_contents| 将 整个 文件 读 入 一 个 字符 串 改变 当前 的 umask 
file 把 整个 文件 读 入 一 个 数组 中 判断 给 定 的 文件 是 否 可 写 
filectime 取得 文件 的 inode 修改 时 间 。 jink 。 ”| 建立 一 个 硬 连 接 
fileinode 取得 文件 的 inode istat | 给 出 一 个 文件 或 符号 连接 的 信息 
fileowner 取得 文件 的 所 有 者 move uploaded file| 将 上 传 的 文件 移动 到 新 位 置 
filesize 取得 文件 大 小 pathinfo ”| 返回 文件 路 径 的 信息 
popen 打开 进程 文件 指针 stat | 给 出 文件 的 信息 
readlink 返回 符号 连接 指向 的 目标 tempname 。 | 建立 一 个 具有 唯一 文件 名 的 文件 
rename 重 命名 一 个 文件 或 目录 设 定 文件 的 访问 和 修改 时 间 
rmdir 删除 目录 删除 文件 


有 关 函 数 的 详细 功能 和 使 用 方法 i 


2. 文件 的 打开 与 读 写 


见 PHP 5 的 帮助 文档 。 


要 想 利用 PHP 对 文件 进行 操作 ， 就 要 先 了 解 有 关 PHP 中 打开 和 读 写 文件 的 相关 函数 。 


(1) fopen0) 函 数 。 
fopen0 函 数 的 格式 如 下 : 


Tesource fopen (string filename, string mode [, bool use_include_path ]) 


该 函数 的 作用 是 打开 文件 或 URL。 其 中 filename 是 要 打开 的 文件 名 ， 必 须 为 字符 串 形 
式 。 如 果 filename 是 scheme://... (如 http://…) 的 格式 ， 则 被 当成 一 个 URL，PHP 将 搜索 协 
议 处 理 器 (也 被 称 为 封装 协议 ) 来 处 理 此 模式 。 如 果 PHP 认为 妃 ename 指定 的 是 一 个 本 地 
文件 (如 num.txt)， 将 尝试 在 该 文件 上 打开 一 个 流 ， 该 文件 必须 是 PHP 可 以 访问 的 ， 因 此 
需要 确认 文件 访问 权限 允许 该 访问 。mode 是 打开 文件 的 方式 ， 必 须 为 字符 形式 ， 可 以 取 以 


下 几 个 值 。 


回 T: 只 读 形式 ， 文 件 指针 指向 文件 的 开头 。 
回 +': 可 读 可 写 ， 文 件 指针 指向 文件 的 开头 。 
回 'w': 只 写 形式 ， 文 件 指针 指向 文件 的 开头 ， 打 开 同 时 清除 所 有 内 容 ， 如 果 文件 不 


Vi 存在 ， 将 党 试 建立 文件 。 
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回 "w+': 可 读 可 写 ， 文 件 指针 指向 文件 的 开头 ， 打 开 同 时 清除 所 有 内 容 ， 如 果 文 件 
不 存在 ， 将 尝试 建立 文件 。 

回 'a: 追加 形式 (只 可 写 入 ),， 文件 指针 指向 文件 的 最 后 ， 如 果 文 件 不 存在 ， 将 尝试 
建立 文件 。 

回 "at": 可 读 可 写 ， 文 件 指针 指向 文件 的 最 后 ， 如 果 文 件 不 存在 ， 将 尝试 建立 文件 。 

(2) fgets0 函 数 。 

fgets0 函 数 的 格式 如 下 : 


string feets (int handle [, int length]) 


该 函数 的 功能 是 从 文件 指针 中 读 取 一 行 。 其 中 handle 是 要 读 入 数据 的 文件 流 指 针 ， 由 
fopen0) 函 数 返回 数值 。length 是 要 读 入 的 字符 个 数 ， 实 际 读 入 的 字符 个 数 是 length-1。 

即 fgets0 函 数 从 handle 指向 的 文件 中 读 取 一 行 并 返回 长 度 最 多 为 length-1 字 节 的 字符 
串 ， 碰 到 换行 符 〈 包 括 在 返回 值 中 )、EOF 或 者 已 经 读 取 了 length-1 字 节 后 停止 (看 先 碰 到 
哪 一 种 情况 )。 如 果 没 有 指定 length， 则 默认 为 1KB， 即 1024B。 出 错时 返回 FALSE。 

(3) fwriteO 函 数 。 

fwrite0 函 数 的 格式 如 下 : 


int fwrite (resource handle, string string [, int length]) 


该 函数 的 功能 是 写 入 文件 ， 与 int fputs(resource handle, string str, int [length]) 功 能 相同 。 
fwriteO 函 数 把 string 的 内 容 写 入 文件 指针 handle 处 .如 果 指 定 了 length, 当 写 入 了 length 
个 字 节 或 者 写 完 了 string 以 后 ， 写 入 就 会 停止 。 
fwrite0 函 数 返回 写 入 的 字符 数 ， 出 现 错误 时 返回 FALSE。 
(4) fclose( 〇 函数。 
feloseO 函 数 的 格式 如 下 : 


bool fclose (resource handle) 


该 函数 的 功能 是 关闭 一 个 已 打开 的 文件 指针 ， 即 将 handle 指向 的 文件 关闭 。 如 果 成 功 
则 返回 TRUE， 失 败 则 返回 FALSE。 文 件 指针 必须 有 效 ， 并 且 是 通过 fopen() 或 fsockopen() 
函数 成 功 打开 的 。 

下 面 就 用 以 上 几 个 简单 的 文件 操作 函数 来 编写 一 个 文本 类 型 的 访客 计数 器 。 

【 例 3.37】 


<! 一 代码 案例 : 访客 计数 器 -> 
<html> 
<head> 
<title> 访 客 计数 器 </tile> 
</head> 
<body> 
<?php 
if (!file_exists("num .txt")){ // 如 果 文 件 不 存在 
wl 
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$fp=fopen("num .txt", "w"): /借助 w 参数 ， 创 建文 件 
felose($fp); /关闭 文件 

echo "num_txt 文件 创建 成 功 ! <br>"; 

} 

$fp=fopen("num.txt","r"); 

@$num=feets($fp,12); // 读 取 11 位 数字 


if ($num=="") $num=0; 
/如 果 文 件 的 内 容 为 室 ， 初 始 化 为 0 


$numr++; /浏览 次 数 加 1 
@felose($fp): /关闭 文件 
$fp=fopen("num.txt", "Ww"); // 只 写 方式 打开 num.txt 文件 
fwrite($fp,$num); // 写 入 加 1 后 结果 
felose($fp); /关闭 文件 

echo "您 是 第 ".$num." 位 浏览 者 "; /浏览 器 输出 浏览 次 数 

?> 

</body> 

</html> 


不 难 发 现 ， 制 作 一 个 文件 类 型 计数 器 的 基本 思路 是 : 打开 一 个 文件 一 读 出 文件 里 面 的 
内 容 〈 数 据 ) 一 数据 +l1 后 再 写 入 该 文件 一 关闭 文件 。 由 于 当 文件 以 可 读 可 写 方式 打开 时 ， 
文件 的 内 容 同时 被 清空 ， 所 以 制作 文件 计数 器 的 具体 步骤 是 : 以 只 读 方式 打开 一 个 文件 一 
读 出 文件 里 面 的 内 容 (数据 ) 一 关闭 文件 一 再 以 可 读 可 写 方式 打开 文件 一 数据 +1 后 再 写 入 
该 文件 一 关闭 文件 。 


3.2.7 目录 的 创建 、 删 除 与 遍历 


目录 的 操作 主要 是 利用 相关 的 目录 函数 来 实现 的 ， 先 来 看 一 下 有 关 的 目录 函数 。 
(1) string getcwd (void): 取得 当前 工作 目录 。 
(2) bool chdir (string directory): 将 当前 目录 改 为 directory。 
(3) new dir(sting directory): 将 输入 的 目录 名 转换 为 一 个 对 象 并 返回 ， 代 码 如 下 。 
class dir { 
dir(string directory ) 
string path 
resource handle 
string read ( void ) 
void rewind (void ) 
void close (void ) 


} 


该 对 象 含有 2 个 属性 和 3 个 方法 。2 个 属性 为 : handle〈 目 录 句 柄 ) 和 path (打开 目录 
的 路 径 )。 
3 个 方法 为 : read (void) 〈 读 取 目 录 )、rewind (void)( 复 位 目录 )、close (void) (关闭 
目录 )。 
/ 这 3 个 方法 与 后 面 将 要 介绍 的 readdir0、rewinddir0 和 closedir0 函 数 的 作用 相同 。 
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(4) resource opendir (string path): 打开 目录 句柄 。path 为 要 打开 的 目录 路 径 。 

(5) string readdir (resource dir handle): 返回 目录 中 下 一 个 文件 的 文件 名 。 文 件 名 以 
在 文件 系统 中 的 排序 返回 。dir_ handle 为 目录 句柄 的 resource， 之 前 由 opendir0 打 开 。 成 功 
则 返回 文件 名 ， 失 败 返 回 FALSE。 

(6) void rewinddir (resource dir handle): 倒 回 目录 句柄 。 将 dir handle 指定 的 目录 流 
重 置 到 目录 的 开头 。dir handle 为 目录 句柄 的 resource， 之 前 由 opendir0 打 开 。 

(7) void closedir (resource dir handle): 关闭 目录 句柄 。 关 闭 由 dir_ handle 指定 的 目录 
流 ， 流 必须 已 被 opendir0 打 开 。 

(8) array scandir (string directory [, int sorting_order]): 列 出 指定 路 径 中 的 文件 和 目录 。 
返回 一 个 aray， 包 含 directory 中 的 文件 和 目录 。 参 数 directory 是 要 被 浏览 的 目录 。 参 数 
sorting_order 是 文件 的 排列 顺序 , 默认 的 排序 顺序 是 按 字母 升序 排列 。 如 果 使 用 了 可 选 参数 
sorting_order( 设 为 1 )， 则 排序 顺序 是 按 字 母 降序 排列 。 

(9) bool chroot (string directory): 将 当前 进程 的 根 目录 改变 为 directory。 本 函数 仅 在 
系统 支持 且 运 行 于 CLI[、CGI 或 嵌入 SAPI 版 本 时 才能 正确 工作 。 此 外 ， 本 函数 还 需要 root 
权限 。 

下 面 举例 说 明 目 录 的 相关 操作 。 

【 例 3.38】 


<!-- 文 件 案例 ;目录 输出 --> 

<html> 

<head> 

<title> 目 录 输 出 </title> 

</head> 

<body> 

<2php 

$dir=getcwd0: // 获 取 当 前 路 径 
echo getcwd0. "<br>"; // 输 出 当前 目录 
S$filesl=scandir($dir); // 列 出 指定 路 径 中 的 文件 和 目录 
$files2=scandir($dir,1):; 

Print_r($files1); // 输 出 指定 路 径 中 的 文件 和 目录 
print_r($files2); 

S$dir=dir($dir); 

echo gettype($dir)."<br>"; 

echo "目录 句柄 :".$dir->handle."<br>"; 

echo "目录 路 径 :".$dir->path."<br>"; 

while ($entry=$dir->read()) 

echo $entry."; <br>"; 

$dir->close(); 

if (chdir("c:/windows")){ 

echo "当前 目录 更 改 成 功 :c:/windows<br>"; 

}else{ 

echo "当前 目录 更 改 失 败 ! <br>"; 


} 
wi 
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?> 
</body> 
</html> 


程序 执行 的 结果 就 是 保存 本 程序 的 目录 及 其 里 面 的 文件 内 容 。 


项 目 3 PHP 中 函数 的 学 习 国 


当然 ， 通 过 这 些 函 数 还 可 以 做 出 企业 网 站 中 的 宣传 图 片 或 商业 网 站 的 广告 。 更 新 这 
些 图 片 时 ， 添 加 删除 图 片 就 可 以 了 。 代 码 如 下 ， 大 家 可 以 自己 运行 测试 《当然 所 需 的 文件 


要 存在 )。 
【 例 3.39】 


<!-- 遍 历 图 片 显示 --> 

<html> 

<head> 

<title> 遍 历 图 片 显示 </title> 
</head> 

<bodY> 

<2php 

$addr="./image/"; 
$dir=dir($addr); 

while ($file_name=$dir->readO){ 
}else{ 

echo "<img sre=".$addr. $file name." width=40 
height = 30>&nbsp:&nbsp:"; 

} 

} 

?> 

</body> 

</html> 


3.2.8 ”其 他 函数 


据 粗 略 统计 ，PHP 5 提供 的 函数 总 数 达 3800 多 个 ， 分 属于 160 多 个 类 别 ， 可 以 说 是 体 
系 极为 庞大 。 这 些 函 数 涵盖 了 PHP 编程 的 方方面面 ， 给 PHP 开发 者 带 来 巨大 的 便利 和 强 


有 力 的 支撑 。 


虽然 本 任务 中 已 经 用 了 很 大 的 篇 幅 介绍 一 些 最 常用 的 函数 ,但 和 PHP 全 部 函数 比 起 来 ， 
仍然 只 是 极 小 的 一 部 分 。 除 此 之 外 ， 还 有 数据 库 函 数 、XML 函数 、Socket 函数 、 正 则 表达 
式 函 数 、COM 与 DOM 函数 、 压 缩 函 数 、MAIL 函数 等 。 这 么 多 的 函数 不 是 短期 学 习 能 
掌握 的 , 这 就 要 求 读者 首先 充分 了 解 PHP 函数 的 体系 , 然后 通过 长 时 间 不 断 的 学 习 、 积累， 


最 终 达到 较 高 的 水 平 。 


学 习 过 程 中 ， 建 议 读者 准备 一 份 中 文 版 的 PHP 官方 手册 ， 这 在 PHP 官方 网 站 和 国内 
其 他 网 站 上 很 容易 下 载 到 。 这 本 手册 涵盖 了 PHP 各 方面 的 知识 ， 并 提供 了 几乎 全 部 函数 的 
介绍 。 可 以 说 PHP 手册 是 PHP 初学 者 以 及 PHP 开发 者 必 不 可 少 的 参考 工具 。 

关于 PHP 的 函数 就 介绍 这 些 。 本 书 中 的 其 他 章节 还 将 根据 需要 介绍 其 他 函数 ， 如 文件 


NA 


练习 

1. 编制 程序 ， 练 习 数 组 函数 、 字 符 串 处 理 函数 的 使 用 。 

2. 常用 的 时 间 / 日 期 函数 有 哪些 ? 在 使 用 时 应 注意 什么 问题 ? 
3. 利用 文件 系统 函数 ， 编 写 一 个 文件 遍历 程序 。 
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项 目 4 
初 识 MySQL 数据 库 


Web 开发 与 数据 库 
MySQL 数据 库 的 介绍 
数据 库 的 安装 与 初始 化 
MySQL 中 的 数据 类 型 
结构 化 查询 语句 概述 


掌握 数据 库 的 安装 与 初始 化 
掌握 MySQL 中 的 数据 类 型 
掌握 结构 化 查询 语句 

掌握 数据 操作 语言 


| 教学 基础 要 求 


掌握 数据 库 的 安装 与 初始 化 
掌握 数据 定义 语言 
掌握 数据 操作 语言 


Vvvyvyv 


Y 


数据 定义 语言 

数据 操作 语言 

数据 查询 语言 (SELECT ) 
数据 库 的 用 户 管理 
phpmyadmin 的 安装 与 使 用 


掌握 数据 定义 语言 
掌握 数据 查询 语言 (SELECT ) 
掌握 phpmyadmin 的 用 法 


掌握 数据 查询 语言 (SELECT ) 
了 解 phhpmyadmin 的 用 法 


任务 1 MySQL 简介 和 创建 新 的 数据 血 


任务 描述 


回 “MySQL 的 简介 

回 ”创建 新 的 数据 库 

回 ”认识 MySQL 中 的 数据 库 
知识 汇总 


4.1.1 Web 开发 与 数据 库 


动态 网 站 开发 离 不 开 数据 存储 ， 而 数据 存储 则 离 不 开 数据 库 。 例 如 ， 可 以 将 注册 用 户 
的 信息 存储 在 一 个 文本 文件 中 ， 以 供 以 后 取 用 。 这 使 得 网 站 增加 了 很 多 交互 性 因素 。 但 是 
文本 文件 并 不 是 存储 数据 的 最 理想 方法 , 数据 库 技术 的 引入 给 网 站 开发 带 来 了 巨大 的 飞跃 。 

数据 库 技术 是 计算 机 技术 中 的 重要 部 分 ， 在 软件 开发 领域 起 着 至 关 重 要 的 作用 。 由 于 
数据 库 技 术 属 于 一 个 专门 的 技术 领域 ， 而 本 书 也 不 是 以 讨论 数据 库 原理 为 目的 ， 因 此 不 再 
对 数据 库 的 理论 进行 曾 述 。 考 虑 到 部 分 读者 可 能 对 数据 库 并 不 熟悉 ， 甚 至 一 无 所 知 ， 为 了 
使 这 部 分 读者 对 数据 库 的 概念 有 一 个 简单 的 认识 ， 为 接 下 来 的 学 习 扫 除 障碍 ， 这 里 用 比较 
通俗 的 语言 描述 一 下 什么 是 数据 库 。 

所 谓 数据 库 ， 可 以 理解 为 用 来 存储 信息 的 “仓库 ”， 而 信息 就 是 要 存储 的 数据 ， 如 用 户 
的 姓名 、 年 龄 ， 产 品 的 价格 、 简 介 ， 某 一 个 日 期 、 时 间 ， 甚 至 图 像 等 。 总 之 ， 一 切 可 以 在 
计算 机 中 存储 下 来 的 数据 都 可 以 通过 各 种 方法 存储 到 数据 库 中 。 

信息 并 不 是 杂乱 无 章 地 直接 放 入 数据 库 ， 而 是 以 二 维 表 的 形式 组 织 起 来 ， 一 条 一 条 地 
存储 于 表 中 ， 这 和 日 常生 活 中 经 常用 到 的 各 种 表格 形式 上 是 一 致 的 。 表 中 的 每 一 条 信息 称 
为 一 条 记录 。 一 个 数据 库 中 可 以 有 若干 张 表 ， 每 张 表 中 又 可 以 存放 若干 条 记录 。 如 前 面 讲 
到 的 用 户 注 册 程序 ， 每 一 个 用 户 的 信息 ， 如 用 户 名 、 密 码 、 头 像 等 ， 就 可 以 作为 一 条 记录 ， 
存储 在 一 张 表 中 。 

每 张 表 都 有 自己 的 表 头 。 如 需要 设计 一 个 用 来 统计 学 生 信息 的 表格 ， 把 要 收集 的 学 生 
信息 分 成 几 个 栏目 ， 这 些 栏目 就 是 表 头 ， 在 数据 库 技术 中 称 为 字段 。 如 表 4.1 所 示 为 一 张 
学 生 基 本 信息 表 ， 其 中 “学 号 和 “姓名 六 “性 别 ”“ 年 龄 ”就 是 字段 ,“ 张 海 ” 就 是 第 一 条 
记录 的 “姓名 ”字段 值 ，20 就 是 第 3 条 记录 的 “年 龄 ”字段 值 。 而 表 中 横向 的 多 个 字段 值 
组 成 了 一 条 记录 ， 多 条 记录 构成 了 一 张 数据 表 。 


表 4.1 学 生 基本 信息 表 
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以 上 简要 说 明了 数据 库 、 表 、 字 段 和 字段 值 这 几 个 概念 。 实 际 上 这 些 概 念 远 比 这 里 介 
绍 的 复杂 得 多 ， 对 此 感 兴趣 的 读者 可 以 参考 数据 库 技术 的 相关 书籍 来 进一步 了 解 。 

把 数据 以 这 种 形式 存放 在 数据 库 中 有 什么 好 处 呢 ? 采取 数据 库 技 术 可 以 给 数据 的 存储 
和 检索 带 来 巨大 好 处 ， 主 要 可 以 归纳 为 以 下 4 点 。 

回 ”数据 存储 集约 化 ， 最 大 限度 节省 存储 空间 。 

回 数据库 专门 的 检索 引擎 能 够 极 大 提高 数据 检索 速度 。 

回 ”数据 库 结构 化 查询 语言 (SQL ) 给 数据 管理 带 来 了 极 大 便利 。 

回 ”可 以 方便 地 对 数据 进行 查询 、 增 加 、 删 除 、 修 改 。 

数据 库 系 统 从 根本 上 说 就 是 一 个 软件 系统 。 通 过 这 个 软件 系统 可 以 对 大 量 数据 进行 存 
储 和 管理 。 当 前 市 场 上 的 数据 库 有 几 十 种 ， 其 中 有 如 Oracle、SQL Server 等 大 型 网 络 数据 
库 ， 也 有 如 Access、VFP 等 小 型 桌面 数据 库 。 对 于 网 站 开发 而 言 ， 一 般 使 用 中 小 型 数据 库 
系统 就 能 满足 要 求 。MySQL 就 是 当前 Web 开发 ， 尤 其 是 PHP 开发 中 使 用 最 为 广泛 的 数 
据 库 。 


4.1.2 ”MySQL 简介 


MySQL 是 MySQL AB 公司 开发 的 一 种 开放 源 代码 的 关系 型 数据 库 管 理 系 统 
(RDBMS), MySQL 数据 库 系统 使 用 最 常用 的 数据 库 管理 语言 一 一 结构 化 查询 语言 (SQL) 
进行 数据 库 管 理由 于 MySQL 是 开放 源 代码 的 ,因此 任何 人 都 可 以 在 General Public License 
的 许可 下 下 载 并 根据 个 性 化 的 需要 对 其 进行 修改 。MySQL 因为 其 速度 、 可 靠 性 和 适应 性 而 
备 受 关注 , 大 多 数 人 都 认为 在 不 需要 事务 化 处 理 的 情况 下 , MySQL 是 管理 内 容 最 好 的 选择 。 

MySQL 关系 型 数据 库 于 1998 年 1 月 发 行 第 一 个 版 本 。 它 使 用 系统 核心 提供 的 多 线程 
机 制 提供 完全 的 多 线程 运行 模式 ， 提 供 了 面向 C、C++、Eiffel、Java、Perl、PHP、Python 
等 编程 语言 的 编程 接口 ， 支 持 多 种 字段 类 型 并 提供 了 完整 的 操作 符 。 

2001 年 , MySQL 4.0 发 布 。 在 该 版 本 中 提供 了 许多 新 的 特性 ， 如 新 的 表 定 义 文件 格式 、 
高 性 能 的 数据 复制 功能 、 更 加 强大 的 全 文 搜索 功能 等 。 目 前 ，MySQL 已 经 发 展 到 MySQL 
5.1， 功 能 和 效率 方面 都 得 到 了 更 大 的 提升 。 

大 概 是 由 于 PHP 开发 者 特别 钟情 于 MySQL， 因 此 才 在 PHP 中 建立 了 完美 的 MySQL 
支持 。 在 PHP 中 ， 用 来 操作 MySQL 的 函数 一 直 是 PHP 的 标准 内 置 函 数 。 开 发 者 只 需要 用 
PHP 写 下 短 短 儿 行 代 码 ， 就 可 以 轻松 连接 到 MySQL 数据 库 。PHP 还 提供 了 大 量 的 函数 来 
对 MySQL 数据 库 进行 操作 。 可 以 说 ， 用 PHP 操作 MySQL 数据 库 极为 简单 和 高 效 ， 这 也 
使 得 PHP+MySQL 成 为 当今 最 为 流行 的 Web 开发 语言 与 数据 库 搭配 之 一 。 

当然 ，PHP 支持 的 数据 库 远 不 止 MySQL 一 种 。 根 据 PHP 官方 提供 的 资料 ，PHP 支持 
几乎 全 部 当前 主流 的 数据 库 。 但 是 PHP 和 MySQL 的 搭配 无 论 是 从 性 能 上 还 是 易 用 性 上 都 
毫 无 疑问 地 成 为 开发 者 的 首选 。 此 外 ， 还 有 一 个 重要 原因 ， 就 是 PHP 和 MySQL 都 是 免费 
和 开放 源 代码 的 ， 并 且 都 有 良好 的 跨 平台 特性 。 这 使 得 搭建 Web 服务 器 的 成 本 几乎 为 零 ， 
而 且 开发 出 来 的 程序 具有 可 移植 性 ， 这 些 都 是 吸引 开发 者 的 重要 原因 。 
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4.1.3 数据 库 的 安装 与 初始 化 


1. 下 载 和 安装 MySQL 安装 包 

虽然 MySQL 5.1 已 经 发 布 ， 但 本 书 以 MySQL 5.0.18 这 个 目前 相对 稳定 的 版 本 为 例 来 
介绍 其 安装 方法 。 其 他 版 本 MySQL 的 安装 方法 也 大 致 相同 ， 读 者 也 可 以 参照 本 节 介绍 的 
方法 进行 安装 和 初始 化 设置 。 

首先 下 载 MySQL 的 安装 包 。 可 以 直接 从 MySQL 的 官方 网 站 下 载 ， 网 址 为 
http://www.mysql.com。 也 可 以 通过 国内 站 点 下 载 ， 如 http://www.mysql.cn。 由 于 本 书 中 的 
例子 都 在 Windows 平台 下 进行 开发 和 调试 ,因此 要 下 载 Windows 平台 下 的 MySQL 安装 包 。 
笔者 下 载 的 是 一 个 名 为 mysql-5.0.18-win32.zip 的 压缩 包 。 通 过 压缩 包 的 名 字 就 可 以 看 出 ， 
该 MySQL 版 本 为 5.0.18， 并 且 适 用 于 Windows 32 位 平台 。 

MySQL 的 具体 安装 和 配置 过 程 如 下 。 

(1) 解压 安装 包 得 到 setup.exe 的 安装 文件 ， 启 动 安装 程序 后 会 出 现 软件 安装 欢迎 界 
面 ， 如 图 4.1 所 示 。 


Welcome to the Setup Wizard for MySQL 
Server 5.0 


The Sebp Weerd wl nee Wyssorver 50 release 5.0.18 
your computer, To continue, dick Next. 


WARNING: This program is protected by copyright law. 


图 4.1 MySQL 数据 库 安装 欢迎 界面 


(2) 单 击 Next 按钮 ， 出 现 选 择 安装 类 型 界面 ， 如 图 4.2 所 示 。 默 认 选择 Typical， 即 
典型 方式 。 这 里 建议 选择 Custom， 即 自 定义 方式 。 因 为 选择 此 项 才能 手工 指定 安装 目录 ， 
否则 将 会 安装 到 默认 目录 。 

(3) 单 击 Next 按钮 ， 出 现 “ 自 定义 安装 ”界面 。 在 这 里 可 以 选择 要 安装 的 组 件 。 
为 安装 全 部 组 件 也 仅 需 要 23MB 的 空间 ， 因 此 建议 不 做 改动 ， 保 持 默 认 设 置 。 界 面 下 方 为 
安装 位 置 ， 默 认为 C:\Program Files\MySQLAMYSQL Server5.0\， 可 以 看 出 该 目录 较为 复杂 ， 
不 便于 将 来 使 用 ， 可 以 单 击 Change 按钮 ， 另 外 选择 一 个 目录 ， 例 如 选择 CA\MysqlS\ 作 为 安 
装 目 录 ， 如 图 4.3 所 示 。 
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ee 项 目 4 初 识 MySQL 数据 库 转 


Setup Type Custom Setup 
Choose the setup type thak best suks your needs. Select the program features you want nstaled, 


Feature Description 
Common program features wil be nstaled, Recommended for | Tea 


LL general use、 


Ocomplete 
Al program features wdl be nataled (Requres the most dk Th osuro eaes 2 on 
Space ) 


过 


OFcustom 
同 Choose which program features you want nstaled and where they 


2 will be installed, Recommended for advanced users. 
Cg J ke> ][ cance 
图 4.2 选择 安装 类 型 图 4.3 选择 安装 组 件 与 目录 
(4) 继续 单 击 Next 按钮 ， 出 现 “准备 就 绪 ， 确 认 安装 ”界面 ， 确 认 无 误 后 单 击 Install 
按钮 ， 此 时 出 现 安装 进度 条 ， 如 图 4.4 所 示 。 安 装 完成 后 ， 会 出 现 MySQL 注册 界面 ， 提 示 
用 户 创 建 一 个 MySQL 通行 证 或 者 登录 MySQL 通行 证 ， 可 以 选中 Skip Sign-Up 单 选 按钮 ， 
直接 跳 过 这 一 环节 ， 如 图 4.5 所 示 。 


Installing MySQL Server 5.0 
The program features you selected are being Instaled. Logn or aeste a new My5QLcom account. 


回 Please waik while the Setup Wizard installs MySQL. Server 5,0, This may take Please log n or select the option to create a new account, 
several minutes. 
Oreate a new free MySQL.com account 


Stakus: dd pi i re 
(option and complete the folowing three steps 


[CECI 


OLoginto MysQLcom 
Select this option F you 动 eady have a MySQL,com account, 
Please specfy your logn information below, 


Emal address! 
Password: 
加 gp son-up 


图 4.4 MySQL 安装 进度 图 45 MySQL 联机 注册 
(5) 单 击 Next 按钮 ， 出 现 安装 完毕 界面 。 这 时 会 询问 是 否 进行 MySQL 服务 器 配置 ， 
建议 保持 复 选 框 选 中 状态 ， 并 单 击 Finish 按钮 ， 以 启动 MySQL 服务 器 配置 向 导 。 
(6) 单 击 Next 按钮 ， 出 现 服务 器 配置 类 型 界面 ， 保 持 选 择 默认 的 Detailed Configuration， 
单 击 Next 按钮 ， 这 时 出 现 3 个 选项 ， 可 以 选择 Developer Machine 或 Server Machine， 这 里 
选择 Developer Machine。 单 击 Next 按钮 ， 出 现 选择 数据 库 用 途 界面 ， 可 以 选择 Multifunctional 
Database， 即 多 功能 数据 库 。 单 击 Next 按钮 ， 出 现 InnoDB 存放 位 置 窗口 ， 保 持 默认 设置 
直接 单 击 Next 按钮 ， 出 现 并 发 连接 数 选择 界面 ， 如 图 4.6 所 示 。 这 里 第 1 个 选项 表示 最 大 
连接 数 为 20， 第 2 个 选项 表示 最 大 连接 数 为 500， 第 3 个 选项 为 自 定义 连接 数 。 在 学 习 阶 
段 ， 建 议 选择 第 1 个 选项 ，20 个 连接 数 足够 使 用 。 如 果 是 真正 配置 Web 服务 器 ， 可 以 根据 
需要 选择 更 大 的 连接 数 。 


NA 
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(7) 单 击 Next 按钮 ， 出 现 端口 选择 界面 。 这 里 就 是 MySQL 数据 库 的 服务 端口 ， 如 
果 没 有 特殊 需要 ， 直 接 使 用 默认 的 3306 端口 即 可 。 单 击 Next 按钮 ， 出 现 字 符 集 设置 界面 ， 
如 图 4.7 所 示 。 第 1 个 选项 为 使 用 默认 字符 集 ， 也 就 是 把 Latinl 作为 默认 字符 集 ， 第 2 个 
选项 为 把 UTF8 设置 为 默认 字符 集 ， 第 3 个 选项 为 自 定义 字符 集 。 


MySQL Server Instance Configuration MySQL Server Instance Configuration 
Configure the My5QL Server 5.0 server instance， Configure the My5QL Server 5.0 server instance， 


Please set the approximate number of concurrenct connections to the server. Please select the default character set, 


Obecision Support (D55)/OLAP] O Standard Character set 


Select ths option for database applcations thak wl nok requre 3 Makes Latinl the defadlt charset This character setis suted for 
总 high number of concurrent connections, A number of 20 connections English and other West European languages. 


OO online Transaction Processing (OLTP) O Best Support For Multilingualism 
or highly concurrent spplcations that may have Make UTFG the default character set. This 5 the recommended 
ny on tine up to S00 Se Commoctione such a hoaviy Daded character set For storing text in many diferent languages, 
Servers, 


OManual Setting © Manual Selected Default Character Set / Collation 


Please enter the approximate number of concurrenk connections. Please speafy the character set to use. 
Concurent connections: [IS 加 Character Set; [ob2312 四 


Csee [EEC 
图 4.6 选择 最 大 连接 数 图 4.7 设置 字符 集 
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字符 集 的 概念 比较 复杂 ， 这 里 不 再 详 述 。 事 实 上 ， 一 般 来 说 采用 什么 样 的 字符 集 对 
MySQL 影响 不 大 ， 只 有 在 不 同 MySQL 之 间 导 入 /导出 数据 时 才 考 虑 字符 集 是 否 一 致 的 问 
题 ,否则 容易 导致 乱码 。 这 里 不 妨 选 择 第 3 个 选项 , 并 把 gb2312 即 简体 中 文 设置 为 字符 集 

(此 处 字符 集 的 设置 将 对 后 期 的 PHP+MYyYSQL 调用 产生 影响 ， 初 学 者 可 以 保持 默认 设置 ， 
即 采用 Latinl ) 。 


(8) 继续 单 击 Next 按钮 ， 出 现 Windows 选项 界面 ， 如 图 4.8 所 示 。 在 这 里 可 以 选择 
是 否 将 MySQL 安装 为 Windows 的 服务 。 这 里 可 以 选择 是 ， 这 样 可 以 在 机 器 启动 时 自动 启 
动 MySQL 数据 库 服 务 。 另 外 ， 建 议 选中 下 面 的 Include Bin Directory in Windows PATH 单 
选 按钮 。 本 选项 的 意思 是 将 MySQL 的 Bin 目录 加 入 到 Windows 的 环境 变量 中 。 这样 做 可 
以 让 用 户 在 命令 行 下 直接 运行 MySQL 命令 ， 而 无 须 先 切换 到 MySQL 的 安装 目录 的 Bin 
目录 下 (MySQL 的 命令 存放 在 安装 目录 下 的 Bin 子 目 录 下 ， 如 C:\mysql5\bin)。 

(9) 继续 单 击 Next 按钮 ， 出 现 安全 选项 界面 。 在 该 界面 中 可 以 设置 MySQL 数据 库 
超级 管理 员 的 密码 。MySQL 安装 完毕 之 后 默认 生成 一 个 用 户 名 为 root 的 超级 管理 员 用 户 ， 
密码 为 空 。 该 用 户 拥有 对 数据 库 的 完全 控制 权限 ， 因 此 为 其 设置 密码 非常 重要 ， 而 且 一 旦 
设置 就 要 牢记 ， 和 否则 很 难 找 回 。 如 果 是 在 服务 器 上 安装 MySQL， 务 必要 设置 这 个 密码 ， 而 
且 设 置 的 越 复杂 越 好 。 如 果 仅 仅 是 在 本 地 机 器 作为 学 习 、 测 试 之 用 ， 为 了 方便 可 以 暂 不 设 
置 密码 。 这 里 将 密码 设置 为 1234。 单 击 Next 按钮 ， 这 时 设置 步骤 完成 ， 出 现 执行 配置 界 
面 ， 单 击 Execute 按钮 ， 开 始 执行 配置 ， 稍 等 片刻 即 可 配置 成 功 ， 如 图 4.9 所 示 。 
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MySQL Server Instance Configuration MySQL Server Instance Configuration 
Configure the My5QL Server 5.0 server nstance. Configure the My5QL Server 5.0 server nstance. 


Please set the Windows options. Processing configuration ，… 


回 Install as Windows Service 
有 This 6 the recommended way torun the MySQL server FS Prepare configuration 
‘on Wndows, 


加 Wrie configuration fie Cimysqsyny nd 
Service Name: [MySat > 
[Launch the MySQL Server automaticaly 


linciude Bin Directory in Windows PATH) 
Check this option to include the directory containing the 
‘server | clent executables in the Windows PATH variable 
so they can be caled from the command ne 
Press [Finish] to close the Wizard. 


Ce 


图 4.8 设置 Windows 选项 图 4.9 配置 完成 

这 时 所 有 配置 工作 都 已 顺利 结束 ， 单 击 Finish 按钮 结束 配置 程序 。 

2， 进入 MYSQL 控制 台 

如 果 安 装 并 配置 成 功 , MySQL 服务 应 该 已 经 被 启动 , 可 以 通过 以 下 方法 进行 简单 的 测 
试 ， 来 验证 MySQL 安装 是 否 成 功 。 

选择 “开始 ”一 “运行 ”命令 ， 执 行 cmd 命令 ， 打 开 命 令 提 示 符 窗口 〈 也 可 以 通过 选 
择 “ 开 始 ” 一 “程序 ”一 “附件 ”一 “命令 提示 符 ” 命 令 来 打开 )， 在 命令 提示 符 下 输入 
mysql -u root -p 并 按 Enter 键 ， 会 出 现 Enter password:， 输 入 密码 1234 按 Enter 键 ， 如 果 
MySQL 安装 成 功 并 已 成 功 启动 ， 会 出 现 如 图 4.10 所 示 的 登录 成 功 的 欢迎 信息 。 


图 4.10 MySQL 登录 成 功 的 欢迎 信息 


根据 软件 环境 不 同 ， 命 令 提示 符 的 显示 信息 可 能 也 会 有 所 不 同 。 但 只 要 输入 密码 后 能 
够 看 到 Welcome to the MySQL monitor 之 类 的 提示 ， 就 说 明 MySQL 登录 成 功 。 如 果 root 
用 户 没有 设置 密码 ， 可 以 在 出 现 Enter Password: 之 后 直接 按 Enter 键 ， 使 用 空 密码 进入 。 
如 果 出 现 “MySQL 不 是 内 部 命令 或 外 部 命令 , 也 不 是 可 运行 的 文件 或 批 处 理 文件 的 提示 ， 
那 说 明 在 上 面 的 配置 步骤 中 没有 把 MySQL 的 Bin 目录 加 入 到 系统 环境 变量 中 。 这 时 可 以 
在 命令 提示 符 下 切换 到 MySQL 的 安装 目录 的 Bin 目录 ， 然 后 输入 mysql -u root -p 命令 来 
登录 MySQL 。 


4.1.4 MySQL 中 的 数据 类 型 


1.， 数据 类 型 
\ 7 这 里 所 说 的 数据 类 型 实际 上 也 是 字段 类 型 ， 即 数据 表 中 的 每 个 字段 可 以 设置 的 类 型 。 
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为 了 对 不 同性 质 的 数据 进行 区 分 ， 提 高 数据 查询 和 操作 的 效率 ， 数 据 库 系 统 都 将 可 存 入 的 
数据 分 为 多 种 类 型 ， 如 姓名 、 人 性别 之 类 的 信息 为 字符 串 型 ， 年 龄 、 价 格 、 分 数 之 类 的 信息 
为 数字 型 ， 日 期 等 为 日 期 /时 间 型 。 这 就 有 了 数据 类 型 的 概念 。 

数据 类 型 是 针对 字段 来 说 的 。 有 的 资料 中 称 为 列 类 型 或 字段 类 型 。 一 个 字段 一 旦 设置 
为 某 种 类 型 ， 该 字段 中 只 能 存 入 该 类 型 的 数据 ， 不 能 写 入 非法 数据 。 如 “年 龄 ”字段 设置 
为 整数 型 ， 那 么 数字 123 可 以 写 入 到 这 个 字段 中 ， 字 符 串 ab 就 无 法 写 入 。 

就 像 编 程 语言 一 样 ， 每 种 数据 库 都 有 自己 支持 的 若干 种 数据 类 型 。 在 数据 库 中 建立 表 
时 ， 首 先 要 考虑 的 就 是 这 个 表 需 要 设置 多 少 个 字段 以 及 每 个 字段 的 数据 类 型 。 

MySQL 数据 库 中 的 数据 类 型 分 为 3 大 类 : 数值 类 型 、 日 期 /时 间 类 型 和 字符 串 类 型 。 
各 大 类 中 包含 的 具体 类 型 及 其 取 值 范围 如 表 4.2 所 示 。 


表 4.2 MySQL 常用 数据 类 型 


大 类 数据 类 型 取 值 范围 或 取 值 格式 
有 符号 : -128 一 127 
TE 无 符号 : 0 一 255 
en 有 符号 : -32768 一 32767 
无 符号 : 0 一 65535 
数值 型 i 有 符号 ，-8388608 一 8388607 
无 符号 : 0 一 16777215 
: -2147483648 一 2147483647 
上 无 符号 : 0 一 4294967295 
有 符号 : -9223372036854775808 一 9223372036854775807 
BIGINT 
无 符号 : 0 一 18446744073709551615 
DATETIME 0000-00-0000:00:00 
DATE 0000-00-00 
日 期 /时 间 型 | TIMESTAMP 00000000000000 
TIME 00:00:00 
YEAR 0000 
CHAR 0~255 ( 字 节 ， 字 符 型 ) 
VARCHAR 0~65535〈 字 节 ， 字 符 型 ) 
BINARY 0~255〈 字 节 ， 二 进 制 型 
字符 串 型 VARBINARY 和 
BLOB 无 限 大 小 〈 字 节 字 符 串 ) 
TEXT 无 限 大 小 〈 字 符 字符 串 ) 
ENUM 枚 举 型 ， 最 多 65535 个 元 素 
SET 集合 型 ， 最 多 64 个 成 员 


读者 可 能 对 表 中 的 数据 类 型 还 很 陌生 ， 在 后 面 的 内 容 中 将 陆续 介绍 其 中 一 些 较为 常用 
的 类 型 。 
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2. 字段 属性 

字段 除了 必须 声明 类 型 之 外 ， 还 可 以 有 各 种 属性 。 如 有 的 字段 值 不 能 为 室 ， 有 的 字段 
可 以 设 成 “key (〈 键 )”， 有 的 字段 可 以 设 成 “Auto_increment 自 增 ?”， 有 的 字段 可 以 规定 长 
度 和 设置 默认 值 等 ， 这 就 涉及 MySQL 的 字段 属性 。 读 者 将 在 后 面 的 学 习 中 逐渐 接触 到 不 
同 的 字段 属性 。 

练习 


1. 数据 库 技术 可 以 给 数据 的 存储 与 检索 带 来 哪些 好 处 ? 
2. 如 何 正确 安装 MySQL 数据 库 ? 


任 分 2 数据 库 藉 作 


任务 描述 

回 数据库 中 常用 的 SQL 语句 

回 数据库 的 用 户 管理 

回 ”MySQL 可 视 化 管理 工具 phpMyadmin 
知识 汇总 


4.2.1 ”结构 化 查询 语句 概述 


结构 化 查询 语言 (Structured Query Language) 最 早 是 IBM 的 圣 约 巧 研究 实验 室 为 其 关 
系数 据 库 管理 系统 SYSTEM R 开发 的 一 种 查询 语言 。 SQL 结构 简洁 、 功能 强大 、 简单 易学 ， 
所 以 自从 1981 年 由 IBM 公司 推出 以 来 , SQL 得 到 了 广泛 的 应 用 。 如 今 无 论 是 Oracle、Sybase、 
SQL Server 等 大 型 的 数据 库 管理 系统 ， 还 是 Visual Foxporo、PowerBuilder 等 小 型 桌面 数据 
库 开发 系统 ， 都 支持 SQL 语言 作为 查询 语言 ，MySQL 也 不 例外 。 

SQL 主要 包含 以 下 4 个 部 分 。 

回 ”数据 定义 语言 ， CREATE、ALTER、DROP。 

回 ”数据 控制 语言 : COMMIT WORK、ROLLBACK WORK。 

回 ” 数 据 查 询 语言 ， SELECT。 

回 ”数据 操作 语言 : INSERT、UPDAIE、DELETE。 

SQL 可 用 于 所 有 用 户 的 数据 库 活 动 模型 ， 包 括 系统 管理 员 、 数 据 库 管 理 员 、 应 用 程序 
、 决 策 支 持 系 统 人 员 及 许多 其 他 类 型 的 终端 用 户 。 基 本 的 SQL 命令 在 很 短 时 间 内 就 能 学 
高 级 的 命令 通过 学 习 也 不 难 掌握 。SQL 可 以 完成 的 功能 包括 : 
回 ”查询 数据 。 
加 ”在 表 中 插入 、 修 改 和 删除 记录 。 
回 建立、 修改 和 删除 数据 对 象 。 
回 ”控制 对 数据 和 数据 对 象 的 存 取 。 


阔 并 


高 等 职业 教育 “十 二 五 ”规划 教材 @ 


[1 225 才 寺 二 


回 ”保证 数据 库 一 致 性 和 完整 性 。 

早期 的 数据 库 管 理 系统 为 上 述 各 类 操作 提供 单独 的 语言 , 而 SQL 将 全 部 任务 统一 在 一 
种 语言 中 。 由 于 所 有 主要 的 关系 数据 库 管理 系统 都 支持 SQL 语言 ， 因 此 用 SQL 编写 的 程 
序 在 一 般 情 况 下 都 具有 可 移植 性 。 

上 面 对 SQL 的 理论 进行 了 介绍 ， 下 面 就 来 介绍 一 些 具体 的 SQL 语句 。 看 SQL 是 如 何 
实现 对 数据 的 操纵 的 。 


4.2.2 ”数据 定义 语言 (CREATE/ALTER/DROP ) 


1. CREATE/SHOW/USE 语句 

CREATE 语句 可 以 用 来 创建 新 的 数据 库 和 表 。SHOW 语句 用 来 显示 当前 所 有 数据 库 或 
当前 数据 库 下 的 所 有 表 。 

根据 本 章 前 面 讲 过 的 方法 ， 打 开 命 令 提 示 符 界面 ， 输 入 用 户 名 密码 登录 到 MySQL 控 
制 台 ， 光 标 前 面 将 显示 mysql>， 在 光标 处 可 以 直接 输入 SQL 语句 来 操作 数据 库 。 接 下 来 
创建 一 个 student 数据 库 ， 输 入 以 下 命令 并 按 Enter 键 。 

mysql> CREATE DATABASE student; 

SQL 语句 可 以 用 大 写 ， 也 可 以 用 小 写 ， 还 可 以 大 小 写 混合 。 本 语句 执行 后 会 输出 : 

Query OK, 1 row affected (0.08 sec) 

这 说 明 语句 执行 成 功 。 一 个 名 为 student 的 数据 库 已 经 被 成 功 创建 。 这 时 可 以 用 以 下 命 
令 来 查看 数据 库 是 否 已 经 被 创建 : 

mysql> SHOW DATABASES; 

输入 命令 后 按 Enter 键 ， 即 可 列 出 当前 所 有 数据 库 。 


mysql> show databases; 


二 十 
| Database | 
+- 一 一 一 一 一 一 十 
| information_schema | 
| mysql | 
| student | 
| test | 
二 -一 一 一 一 一 -一 十 


4 rows in set (0.13 sec) 


可 以 看 到 ，student 数据 库 已 经 成 功 创建 (information _ schema、mysql、test 3 个 数据 库 
均 为 MySQL 安装 时 自动 创建 的 原始 数据 库 )。 

继续 用 CREATE 语句 在 student 数据 库 中 创建 一 个 表 info。 该 表 用 来 存储 学 生 基本 信息 ， 
一 共有 3 个 字段 ， 分 别 是 姓名 (name)、 性 别 〈sex) 和 年 龄 (age)。 这 3 个 字段 对 应 的 数 
据 类 型 分 别 为 CHAR、CHAR、TINYINT， 长 度 分 别 限 制 在 20B、2B、2B 以 内 。 
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在 student 数据 库 中 创建 表 之 前 ， 需 要 首先 打开 这 个 数据 库 : 
mysql> USE student; 
此 语句 用 USE 命令 选 定 一 个 要 操作 的 数据 库 。 执 行 后 显示 Database changed， 表 示 数 
据 库 已 经 打开 。 


然后 输入 以 下 语句 并 按 Enter 键 : 


mysql> CREATE TABLE info (name CHAR(20), sex CHAR(2), age TINYINT(2)); 


[ead 
注意 
每 条 SQL 语句 输入 完毕 后 最 后 要 输入 “;”, 表示 输入 完成 。 否 则 , 不论 按 多 少 次 Enter 
键 此 语句 都 不 会 执行 ， 直 到 遇 到 分 号 结尾 ( 也 有 极 个 别 语句 可 以 不 加 分 号 ) 。 


语句 执行 完毕 后 显示 Query OK, 0 rows affected (0.14 sec)， 表 示 语 句 执行 成 功 。 这 时 表 
info 已 经 成 功 创建 ， 可 以 使 用 以 下 命令 来 查看 student 数据 中 现 有 的 表 。 


mysql> SHOW TABLES; 
执行 后 显示 : 
和 十 

| Tables_in_student | 
sse 十 

| info | 
es 十 


1 row in set (0.00 sec) 

2. ALTER 语句 

ALTER 语句 用 来 修改 一 个 表 的 定义 ， 即 修改 表 自 身 ， 如 修改 表 的 名 字 ， 修 改 表 中 某 个 
字段 的 名 字 、 属 性 、 类 型 等 (也 可 以 用 于 修改 数据 库 的 部 分 属性 )。 例 如 : 

mysql> ALTER TABLE info CHANGE name xingming CHAR (20); 

本 语句 将 表 info 的 name 字段 名 修改 为 xingming， 类 型 和 长 度 不 变 。 又 如 : 

mysql> ALTER TABLE info ADD addr CHAR (50); 

本 语句 在 info 表 中 又 增加 了 一 个 名 为 addr， 类 型 为 CHAR， 长 度 为 50 的 新 字段 。 再 如 : 

mysql> ALTER TABLE info DROP addr: 

本 语句 删除 了 表 info 中 的 addr 字段 。 

3. DROP 语句 


DROP 语句 用 来 删除 一 个 数据 库 或 者 一 个 表 。 如 果 是 删除 一 个 数据 库 ， 那 么 这 个 数据 
库 下 的 所 有 表 也 将 被 删除 。 例 如 : 
\Y/ 


- 多 一 高等 职业 教育 “十 二 五" 规划 教 村 @ 


mysql> DROP DATABSE D1: 
删除 名 为 D1 的 数据 库 。 
mysql> DROP TABLE tbll; 


删除 名 为 tbll 的 表 删 除 前 需要 先 打开 数据 库 )。 


4.2.3 ”数据 控制 语言 (COMMIT WORK, ROLLBACK WORK ) 


COMMIT 命令 用 于 把 事务 所 做 的 修改 保存 到 数据 库 ， 它 把 上 一 个 COMMIT 或 
ROLLBACK 命令 之 后 的 全 部 事务 都 保存 到 数据 库 。 

ROLLBACK 命令 用 于 回归 当前 事务 , 即 撤销 该 事务 中 所 有 SQL 语句 对 数据 库 的 更 新 ， 
这 样 ， 数 据 库 就 会 恢复 到 执行 该 事务 第 一 条 语句 之 前 的 状态 

在 上 面 两 条 语句 中 ，work 关键 字 都 是 可 选 的 。 

这 两 个 命令 的 语法 分 别 是 : 


commit [work]: 和 rollback [work]: 


关键 字 COMMIT 和 ROLLBACK 是 语法 中 唯一 不 可 缺少 的 部 分 , 其 后 是 用 于 终止 语句 
的 字符 或 命令 , 具体 内 容 取 决 于 不 同 的 实现 。 关键 字 WORK 是 个 选项 ， 其 唯一 作用 是 让 命 
令 对 用 户 更 加 友好 。 

在 下 面 这 个 范例 里 ， 我 们 首先 从 表 info 里 的 全 部 数据 开始 : 


select * FROM info; 

name SeX age 
张 三 男 20 
李 四 男 18 
人 女 18 
赵 六 女 17 


4 rows selected 
接 下 来 ， 删 除 表 里 年 龄 低 于 18 的 信息 。 


delete from info 
where age<18; 
1 rows deleted 


使 用 一 个 COMMIT 语句 把 修改 保存 到 数据 库 ， 完 成 这 个 事务 。 


COMMIT:; 

commit complete 

或 使 用 一 个 rollback 语句 撤销 修改 恢复 到 修改 前 的 数据 库 ， 完 成 这 个 事务 。 
ROLLBACK:; 

rollback complete 
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对 于 数据 库 的 大 规模 数据 加 载 或 撤销 来 说 ， 应 该 多 使 用 COMMIT 语句 然而 ， 过 多 
| COMMIT 语句 会 让 工作 需要 大 量 额外 时 间 才能 完成 。 


记 住 ， 全 部 修改 都 首先 被 送 到 临时 回 退 区 域 ， 如 果 这 个 临时 回 退 区 域 没有 空间 了 ， 床 
能 保存 对 数据 库 所 做 的 修改 ， 数 据 库 很 可 能 会 挂 起 ， 禁 止 进 行进 一 步 的 事务 操作 。 


IR 

在 某 些 实现 里 ， 事 务 不 是 通过 使 用 COMMIT 命令 提交 的 ， 而 是 由 退出 数据 库 的 操作 
引发 提交 。 但 是 ， 在 某 些 实现 里 ， 比 如 MySQL， 在 执行 SETTRANSACTION 命令 之 后 ， 
在 数据 库 收 到 COMMIT 或 ROLLBACK 之 前 ， 自 动 提交 功能 是 不 会 恢复 的 。 


sse 


4.2.4 数据 查询 语言 (SELECT ) 


SELECT 语句 用 来 查询 表 中 的 数据 。SELECT 语句 是 SQL 中 最 复杂 的 语句 之 一 。 因 为 
用 SELECT 语句 可 下 如 可 以 查询 某 个 表 中 全 部 记录 、 部 分 满足 
条 件 的 记录 、 全 部 字段 、 部 分 满足 条 件 的 字段 等 。 还 可 以 同时 从 多 个 表 中 查询 满足 条 件 的 
记录 ， 以 及 对 查询 结 果 进 行 排序 等 。 

这 里 仅 介绍 几 种 常用 的 SELECT 语句 ， 读 者 可 以 参考 其 他 数据 库 专 业 书籍 来 更 加 深入 
地 学 习 。 

(1) 查询 全 部 记录 的 全 部 字段 。 

查询 一 个 表 中 全 部 记录 ， 可 以 用 如 下 语句 : 

mysql> SELECT * FROM info: 


这 里 “*” 表 示 所 有 字段 ，info 为 表 名 。 程 序 执行 后 输出 : 


4 rows in set (0.02 sec) 

可 见 刚才 插入 的 4 条 数据 全 部 被 查询 出 来 了 。 

(2) 查询 全 部 记录 的 部 分 字段 值 。 

可 以 通过 指定 具体 的 字段 和 排序 方式 ， 来 过 滤 掉 不 需要 显示 的 字段 。 如 要 查询 所 有 记 
录 的 姓名 、 年 龄 两 个 字段 值 ， 可 以 用 如 下 语句 : 


NTv mysql> SELECT name,age FROM info: 
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执行 后 输出 : 


十 ------ 十 ------ 十 


|name| age | 
ai HH 十 
| 张 三 | 20 | 
| 李 四 | 18 | 
| 王 五 | 18 | 
| 赵 六 | 17 | 


十 ------ 十 ------ 十 
4 rows in set (0.00 sec) 
(3) 查询 满足 某 个 条 件 的 记录 。 
通过 SELECT 语句 的 WHERE 子 句 ， 可 以 查询 某 些 满足 指定 条 件 的 记录 ， 这 在 查询 中 
极为 常用 。 如 要 查询 所 有 年 龄 小 于 19 的 记录 ， 可 以 用 如 下 语句 : 
mysql> SELECT * FROM info WHERE age<19; 


执行 后 输出 : 


十 -十 ------ 十 ------ 十 
|name| sex | age | 
十 -一 -一 一 十 


| 李 四 | 男 | 18 | 
| 王 五 | 女 | 18 | 
| 赵 六 | 女 | 17 | 


十 ------ 十 --- 一 -十 -一 -十 
3 Iows in set (0.01 sec) 


当 查 询 条件 有 多 个 时 ， 可 以 使 用 AND 关键 字 。 如 现在 查询 所 有 年 龄 小 于 19 并 且 性 别 
为 女 的 记录 ， 可 以 使 用 下 列 语句 : 
mysql> SELECT * FROM infor WHERE age<19 AND sex =" 女 "; 


该 语句 执行 后 ， 将 只 输出 满足 条 件 的 “ 王 五 ^“ 赵 六 ”两 条 记录 。 
(4) 查询 某 些 记录 ， 并 对 结果 进行 排序 。 
使 用 SELECT 语句 的 ORDER BY 子 句 可 以 对 查询 结果 进行 排序 。 如 查询 所 有 性 别 为 
女 的 记录 ， 并 且 将 结果 按照 年 龄 从 小 到 大 排序 。 
mysql> SELECT * FROM info WHERE sex= " 女 "ORDER BY age ASC; 


运行 后 输出 结果 如 下 : 


二 ———— 二 -一 -十 
|name| sex | age | 
十 -一 --- 一 二 -一 -十 
| 赵 六 | 女 | 17 | 
站 重 泪 二 雪 汪 让 
十 -一 -一 一 十 -一 -十 
2 rows in set (0.01 sec) 和 
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如 果 要 将 从 小 到 大 改 为 从 大 到 小 排列 ， 则 将 命令 中 的 ASC 改 为 DESC 即 可 。 

本 节 简 要 地 介绍 了 一 些 Web 开发 中 最 为 常用 的 SELECT 语句 , 这 些 语 句 能 够 满足 一 般 
Web 开发 的 需求 。 在 后 面 的 编程 中 经 常会 用 到 SELECT 语句 , 读者 应 注意 多 积累 、 多 比较 、 
多 练习 ， 人 掌握 尽量 多 的 SELECT 语句 的 使 用 方法 ， 才 能 在 以 后 的 开发 中 得 心 应 手 。 


4.2.$S 数据 操作 语言 (INSERT/UPDATE/DELETE ) 


1. INSERT 语句 

INSERT 语句 用 来 向 表 中 插入 新 的 数据 记录 ， 每 次 插入 一 条 。 如 要 向 刚才 创建 的 info 
表 中 插入 一 条 各 字段 值 分 别 为 “ 何 七 ””“ 男 ”“20” 的 记录 ， 可 以 使 用 下 面 的 语句 : 

mysql> INSERT INTO info VALUES (" 何 七 "，" 男 "，20); 


执行 后 显示 Query OK, 1 row affected (0.08 sec)， 表 示 语 句 执行 成 功 。 

值得 注意 的 是 ， 在 插入 数据 时 ， 字 符 串 型 值 要 用 双 引 号 或 者 单 引号 引起 来 ， 数 值 型 不 
用 引号 〈 加 引号 将 出 错 )。 而 且 提供 的 数据 也 必须 按照 表 的 字段 顺序 排列 ， 不 能 颠倒 。 

后 面 将 介绍 如 何 从 表 中 查询 数据 。 在 查询 之 前 ， 先 执行 几 次 INSERT 语句 向 表 中 插入 
几 条 信息 ， 这 样 可 以 更 加 形象 地 说 明 查 询 语 句 的 作用 。 不 妨 再 插入 “ 李 四 ”“ 王 五 ””“ 赵 
六 ”3 条 记录 ， 这 样 表 中 共有 4 条 记录 。 

2. UPDATE 语句 

UPDATE 语句 可 以 对 表 中 现 有 的 记录 进行 修改 。 

(1) 修改 全 部 记录 的 某 个 字段 的 值 。 

例如 要 将 info 表 中 全 部 记录 的 年 龄 都 修改 成 25， 可 以 使 用 下 面 的 语句 : 

mysql> UPDATE info SET age=25; 


这 时 如 果 用 SELECT 语句 查询 此 表 , 会 看 到 所 有 记录 的 age 字段 都 变 成 了 25〈 读 者 可 
以 执行 SELECT * FROM info; 语句 来 查看 表 中 的 数据 。 

此 外 ， 还 可 以 一 次 修改 多 个 字段 的 值 。 如 除了 要 将 所 有 记录 的 age 字段 修改 成 25， 还 
要 将 所 有 sex 记录 修改 为 “ 女 ”， 可 以 用 如 下 语句 : 

mysql> UPDATE info SET age = 25, sex = " 女 "; 

也 就 是 说 ， 修 改 多 个 字段 的 值 时 ， 多 个 字段 之 间 用 逗号 隔 开 。 

(2) 修改 满足 某 条 件 的 记录 。 

通过 WHERE 子 句 指定 的 条 件 , 可 以 修改 满足 指定 条 件 的 记录 的 值 。 如 要 将 姓名 为 “ 张 
三 ”的 记录 的 年 龄 修改 成 23， 可 以 用 如 下 语句 : 


mysql> UPDATE info SET age = 23 WHERE name = " 张 三 "; 


执行 之 后 再 用 SELECT 语句 查询 此 表 ， 会 发 现 “ 张 三 ”的 年 龄 为 23， 其 他 记录 的 年 龄 
均 为 25。 


同样 可 以 用 去 号 隔 开 的 方法 ， 修 改 满 足 指定 条 件 的 记录 的 多 个 字段 。 
3. DELETE 语句 


DELETE 语句 用 来 删除 表 中 的 记录 ， 可 以 一 次 删除 全 部 记录 ， 也 可 以 删除 满足 指定 条 
件 的 记录 。 
(1) 删除 表 中 的 全 部 记录 。 
如 要 删除 表 info 中 的 全 部 记录 ， 可 以 用 以 下 语句 : 


mysql>DELETE FROM info; 


该 语句 执行 后 表 info 中 的 全 部 记录 都 会 被 删除 。 可 以 看 出 该 命令 是 比较 危险 的 ， 很 容 
易 造 成 误 删 ， 带 来 意 想不到 的 后 果 。 因 此 使 用 此 命令 时 应 尽量 注意 。 

(2) 删除 满足 条 件 的 记录 。 

如 果 要 删除 表 info 中 性 别 为 “ 女 ” 的 记录 ， 可 以 用 如 下 命令 : 

mysql> DELETE FORM info WHERE sex = " 女 "; 

读者 可 以 自行 尝试 变换 条 件 ， 来 观察 语句 运行 效果 。 
4.2.6 数据库 的 用 户 管理 


前 面 进入 MySQL 控制 台 时 ， 使 用 的 是 MySQL 的 超级 管理 用 户 ， 即 用 户 名 为 root 的 
et 事实 上 ， 在 实际 应 用 中 一 台数 据 库 服 务 器 往往 多 人 同时 使 用 ， 这 时 如 果 只 有 一 个 用 
账号 显然 不 够 。 而 且 root 用 户 拥 有 对 数据 库 的 全 部 权限 ， 可 以 对 数据 库 进行 任意 操作 ， 
et -个 一 般 的 管理 员 使 用 。 因 此 需要 在 MySQL 中 分 配 账号 ， 每 个 账号 管理 各 

自 的 数据 库 ， 不 能 越权 ， 这 样 可 以 很 好 地 提高 数据 库 的 安全 性 。 

在 MySQL 中 , 增加 新 用 户 的 方法 主要 有 两 个 : 一 是 直接 向 MySQL 用 户 表 中 插入 新 记 
录 ; 二 是 使 用 GRANT 授权 命令 。 

MySQL 的 用 户 账号 和 密码 以 及 权限 等 信息 , 都 存储 在 一 个 名 为 mysql 的 数据 库 的 user 
表 中 (MySQL 安装 完成 后 自动 创建 ， 可 以 在 控制 台 下 查看 )。 分 别 执行 以 下 两 个 命令 : 


mysql> use mysql 
mysql> select * from user; 


这 时 可 以 看 到 类 似 于 下 面 样式 的 返回 结果 以 下 结果 进行 过 简化 ): 


二 -一 一 一 二 一 -下 -一 -一 一 -一 +-- 一 -一 -一 +-- 一 一 一 一 二 -一 一 
| Host | User | Password ~ 

1% | root | lc8bc9fa64c40b82 ~ 

十 一 -一 一 二 -一 -一 十 一 -一 一 一 一 + 一 -一 一 +-- 一 一 一 一 二 一 一 


1 rows in set (0.00 sec) 


可 以 看 到 查询 出 了 user 表 中 的 记录 ， 每 条 记录 就 是 一 个 用 户 账 号 信息 。 由 于 user 表 有 
数 十 个 字段 ， 因 此 读者 看 到 的 查询 结果 可 能 显示 的 比较 凌乱 ， 这 是 由 于 屏幕 尺寸 有 限 ， 无 
法 在 一 行内 显示 出 所 有 字段 ， 自 动 换行 所 导致 的 。 \ 人 (/ 
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新 安装 的 MySQL， 一 般 user 表 中 有 两 个 用 户 ， 分 别 是 root 和 匿名 用 户 。 匿 名 用 户 即 
不 需要 用 户 名 和 密码 即 可 进入 系统 的 用 户 。 
在 user 表 中 ， 前 3 个 字段 Host、User、Password 分 别 表 示 登 录 主 机 、 用 户 名 和 密码 。 
登录 主机 表示 此 用 户 人 允许 登录 的 主机 地 址 ， 即 人 P 地 址 ，% 表 示 任 意 主机 。 如 果 本 用 户 只 能 
从 本 地 登录 , 不 允许 远程 登录 , 可 以 用 localhost 或 本 机 瑟 地 址 。 用 户 密码 用 加 密 方式 存储 ， 
因此 看 到 的 密码 是 一 串 无 规则 的 字符 串 。 第 4 个 字段 以 后 的 字段 表示 权限 状态 ， 即 该 用 户 
是 否 有 某 权限 ， 包 括 查 询 权 限 、 修 改 权限 、 删 除权 限 等 。 

知道 MySQL 存储 用 户 的 基本 原理 后 ， 就 自然 可 以 想到 ， 增 加 一 个 用 户 的 第 一 种 方法 
就 是 直接 向 这 个 表 中 插入 新 记录 。 但 是 由 于 user 表 字段 较 多 ， 用 INSERT 语句 向 表 中 插入 
记录 比较 麻烦 ， 因 此 这 种 方法 虽然 可 行 ， 但 很 少 被 采用 。 

创建 新 用 户 以 及 为 用 户 分 配 权限 的 第 二 种 方法 是 使 用 GRANT 命令 .GRANT 命令 功能 
强大 ， 相 比 于 直接 插入 用 户 简单 得 多 ， 因 此 被 较 多 采用 。 下 面 是 GRANT 命令 的 语法 结构 : 

GRANT priv_type [(column list)] [, priv_type [(column list)] ...] 

ON {tbl name |* |*.* |db name.*} 

TO user_name [IDENTIFIED BY 'password'] 


[, user_name [IDENTIFIED BY 'password'] ...] 
[WITH GRANT OPTION] 


这 是 完整 的 GRANT 语句 语法 结构 ， 看 起 来 比较 复杂 。 使 用 本 命令 可 以 一 次 创建 多 个 
MySQL 账号 。 在 实际 应 用 中 一 般 一 次 只 创建 一 个 用 户 ， 这 样 语法 结构 就 可 以 简化 为 : 
GRANT priv_type [(column list)]] 


ON {tbl name|*|*.*|db name.*} 
TO user name [IDENTIFIED BY ‘password'] 


而 到 了 具体 的 语句 中 ， 还 可 以 继续 简化 。 如 : 
mysql> GRANT ALL ON DB1.* to "Nie" IDENTIFIED BY "123456"; 


此 语句 执行 之 后 创建 用 户 Nie， 密 码 为 123456， 该 用 户 对 数据 库 DB1 拥有 全 部 权限 。 
下 面 对 GRANT 语句 的 语法 结构 进行 简要 分 析 。 
回 GRANT- 一 关键 字 ， 表 示 授 权 语句 开始 。 
加 ”priv_type 一 一 权限 类 型 ， 可 以 是 select、delete、update、create、drop 、alter 等 任意 
一 种 。 如 果 是 全 部 权限 ， 可 以 用 all privileges， 并 且 可 以 简写 为 all。 

回 ON { tbl name |* |*.* | db_name.*} 一 一 声明 此 用 户 可 以 操作 哪些 数据 库 以 及 哪些 
。 声 明 可 以 使 用 以 下 4 种 方法 之 一 。 

tbl name: 直接 指定 表 名 ， 如 info。 

*， 任意 表 。 

#.*#: 任意 数据 库 的 任意 表 。 

db_name.*: 指定 数据 库 的 所 有 表 ， 如 db1。 

回 TO user name: 指定 用 户 名 ， 即 要 创建 的 账号 的 用 户 名 ， 如 上 例 中 的 Nie。 

NW 回 IDENTIFIED BY: 为 可 选项 。 指 定 账 号 所 对 应 的 密码 ， 应 用 引号 引起 来 。 密 码 提 
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交 后 会 自动 被 加 密 。 
以 上 介绍 了 MySQL 中 用 户 管理 的 基本 方法 ， 重 点 讲解 了 GRANT 语句 的 使 用 方法 。 


实际 应 用 中 该 语句 十 分 灵活 、 方 便 ， 熟 练 掌握 GRANT 语句 可 以 在 进行 MySQL 管理 时 游 
刃 有 余 。 


4.2.7 phpMyAdmin 的 安装 和 使 用 


1. phpMyAdmin 的 安装 

在 命令 提示 符 下 编写 语句 来 进行 数据 库 管 理 ， 虽 然 能 够 比较 灵活 地 对 数据 进行 操控 ， 
但 是 具有 难度 高 、 效 率 较 低 、 容 易 出 错 等 棘 端 。 很 多 对 命令 提示 符 不 熟悉 的 读者 更 是 难以 
接受 。 实 际 上 还 有 更 加 高 效 和 便捷 的 方法 来 管理 数据 库 ， 那 就 是 借助 现 有 的 工具 。 
phpMyAdmin 就 是 一 个 专门 用 来 管理 MySQL 数据 库 的 工具 ， 这 也 是 目前 应 用 最 为 广泛 的 
MySQL 数据 库 管 理工 具 。 

phpMyAdmin 不 是 一 般 的 桌面 应 用 软件 ， 它 是 完全 用 PHP 开发 的 一 套 程序 ， 可 以 安装 
在 安装 了 PHP 和 MySQL 的 计算 机 上 ， 通 过 浏览 器 来 管理 MySQL 数据 库 。 该 程序 功能 强 
大 、 界 面 友 好 ， 是 PHP+MySQL 开发 者 十 分 青睐 的 工具 软件 。phpMyAdmin 的 压缩 包 可 以 
从 网 上 下 载 ， 通 过 搜索 引擎 很 容易 就 能 找到 其 下 载 地 址 ， 也 可 以 在 http:/www.mysql.cn 上 

下 载 。 该 软件 有 诸多 版 本 ， 在 此 以 2.8.0 版 本 为 例 来 说 明 其 使 用 方法 。 

将 下 载 的 压缩 包 解 压缩 ， 能 得 到 一 个 包含 大 量 PHP 程序 的 文件 夹 ， 此 文件 夹 一 般 名 为 
phpMyAdmin-xx.xx.xx。 为 了 将 来 使 用 方便 ， 可 以 将 此 文件 夹 重 命名 ， 不 妨 命名 为 
phpmyadmin。 

将 phpmyadmin 文件 夹 复制 到 IIS 或 Apache 主 目录 下 , 这 样 就 可 以 通过 http://localhost/ 
phpmyadmin/ 来 运行 此 程序 。 

打开 phpmyadmin/scripts/ 文 件 夹 ， 找 到 config.default.php， 将 其 重 命名 为 config.inc.php 

(注意 ， 在 不 同 版 本 下 此 文件 的 存放 位 置 可 能 略 有 不 同 ， 如 有 的 版 本 此 文件 直接 存放 在 根 
目录 下 ， 如 找 不 到 可 使 用 搜索 功能 查找 )， 将 此 文件 复制 到 phpmyadmin/ 目 录 下 ， 然 后 打开 
此 文件 ， 找 到 $cfg['Servers'][$il[password'] 项 ， 将 其 值 设 置 为 MySQL 的 超级 用 户 密码 ， 如 
图 4.11 所 示 。 


文件 中 编辑 E) 查看 QW) 插入 GD) 格式 @) 帮助 中 
口 态 目 人 SQ 由 ¥ 有 mS 


$cfel’ Servers' "] [$i] [auth type’] = 'confie’;  // huthentication 生 
$cfel” [$1] Cuser'] 
Scfe 


= "root”; // MySQL user 
$cfel’ Servers’ ] [$i] [" only_db’ ] 


krtar' Sormere’ TEP hide Wh 1 
| 
| 要 “帮助 ”, 请 按 Fi 


图 4.11 修改 phpMyAdmin 配置 文件 


如 果 超 级 用 户 用 户 名 不 是 root， 还 需要 将 此 文件 中 的 Scfg['Servers'][$il[user] 修 改 为 超 
级 用 户 的 用 户 名 。 \ 171/ 
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修改 完毕 之 后 保存 文件 。 这 时 在 浏览 器 中 输入 http://localhost/phpmyadmin/index.php， 
就 打开 了 phpMyAdmin 的 管理 界面 ， 如 图 4.12 所 示 。 
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图 4.12” phpMyAdmin 运行 界面 

2. phpMyAdmin 的 使 用 

(1) 创建 新 数据 库 。 

要 创建 一 个 新 数据 库 ， 在 phpMyAdmin 界面 右 侧 的 “创建 一 个 新 数据 库 ” 下 输入 数据 
库 名 称 ， 单 击 “创建 ”按钮 即 可 ， 如 图 4.12 所 示 。 

(2) 选择 数据 库 。 

在 界面 左 侧 的 下 拉 菜 单 中 选择 一 个 数据 库 ， 下 面 将 列 出 该 数据 库 中 的 所 有 表 ， 右 侧 将 
列 出 数据 库 中 表 的 信息 ， 如 图 4.13 所 示 。 

TT 
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图 4.13 选择 数据 库 


(3) 选择 并 浏览 表 信 息 。 


单 击 左 侧 的 表 名 ， 右 侧 将 显示 此 表 的 详细 字段 信息 ， 如 图 4.14 所 示 。 
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char(20) gb2312_chinese_ci 
char(2) gb2312_chinese_ci 
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这 时 单 击 右 侧 上 方 的 按钮 ， 


局 # Taet 
图 4.14 浏览 表 信 息 
可 以 进行 浏览 表 内 记录 、 浏 览 表 的 结构 、 执 行 SQL 语句 、 


搜索 、 插 入 数据 、 导 出 数据 等 操作 。 


(4) 浏览 及 编辑 数据 。 


单 击 表 上 方 的 “浏览 ”按钮 后 ， 会 打开 该 表 的 记录 。 在 此 视图 中 可 以 对 各 条 记录 进行 
浏览 、 修 改 、 删 除 等 操作 ， 如 图 4.15 所 示 。 
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图 4.15 记录 的 浏览 和 编辑 


phpMyAdmin 是 一 款 功能 强大 的 软件 ， 可 以 很 容易 地 对 MySQL 数据 库 进行 各 种 管理 
本 书 限于 篇 幅 ， 就 不 再 详细 讲解 其 使 用 方法 ， 只 是 将 此 工具 介绍 给 广大 读者 ， 请 各 位 读者 
自行 安装 、 试 用 ， 掌 握 其 常用 功能 ， 这 对 于 提高 数据 库 管理 效率 有 很 大 帮助 。 


4.2.8 ”MySQL 实例 操作 


本 实例 的 第 一 部 分 是 安装 并 


配置 MySQL。 只 要 根据 本 章 所 讲 的 内 容 逐 步 操 作 , 就 可 以 


轻松 完成 。 目 的 是 让 读者 亲自 动手 ， 熟 练 掌握 MySQL 的 安装 与 配置 步骤 。 
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本 实例 的 第 二 部 分 是 建立 一 个 用 户 信息 表 。 可 以 用 SQL 语句 在 命令 提示 符 下 建立 ,也 
可 以 用 phpMyAdmin 来 建立 。 这 里 使 用 phpMyAdmin。 

结合 5.1.6 中 改写 用 户 注册 与 登录 过 程 , 很 容易 分 析出 ,这 个 用 户 信 息 表 只 需要 取代 文 
本 文件 的 功能 即 可 。 用 户 信息 只 有 登录 名 、 登 录 密 码 和 头像 3 个 字段 。 这 样 可 以 设计 有 3 
个 字段 的 表 ， 分 别 用 来 存储 登录 名 、 登 录 密 码 和 头像 地 址 〈 要 注意 这 里 并 不 是 把 图 片 直接 
存 入 表 中 ， 而 是 把 图 片 的 名 字 和 路 径 存 入 表 中 )。 

另外 , 由 于 本 实例 不 要 求 必须 新 建 一 个 数据 库 , 可 以 把 表 建 立 在 前 面 已 经 建成 的 student 
数据 库 中 。 

有 具体 实施 步骤 如 下 。 

(1) 打开 phpMyAdmin， 选 择 左 侧 的 student 数据 库 ， 右 侧 出 现 数据 库 属 性 。 找 到 “在 
数据 库 student 中 创建 一 个 新 表 ” 然后 在 “名 字 ” 文 本 框 中 输入 表 的 名 称 , 这 里 输入 userinfo， 
在 Number of fields〈 即 字段 个 数 ) 文本 框 中 输入 3， 如 图 4.16 所 示 。 
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图 4.16 创建 一 个 新 表 


(2) 单 击 “ 执 行 ”按钮 ， 此 时 会 出 现 表 字段 设置 界面 ， 根 据 需 求 ， 将 3 个 字段 都 设置 
为 VARCHAR 类 型 ， 并 为 其 指定 最 大 字 节 数 。 其 他 属性 可 以 根据 具体 需要 设置 ， 如 图 4.17 
所 示 。 


ont / localhont / atudont / usorinfo | phpyAdmin 2.8.0. 
文件 四 ”多 儿 于) 查看。 收藏 人 工具 人 雪 助 吕 


@iE- 恒 国 国 的 有 记 开交 tex @ 全 -学 日 - 国 煞 不 沪 
地 站 加 痢 Mtp /localhestphonysinin index. pp 加 # 
日 器: 1ocalhost ， 厚 要 据 库 : 


字段 类 型 @ 长 度 / 值 *! 


[usemame [vARCcHAR 峡 历 


varcHar Wl 


[大 和 | 或 添加 11 ”| 字段 Ea 


本 地 Intranet 


图 4.17 字段 属性 设置 
7/ 
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(3) 设置 完成 后 ， 单 击 “ 保 存 ” 按 钮 ， 此 表 即 创建 成 功 。 这 时 再 看 左 侧 ， 
两 个 表 了 ， 如 图 4.18 所 示 。 


和 userinfo 


了 
文件 四 


Ae- 


alho: 


地 直 四 ) | 罩 http /1localhest/phpaysdaimyindex 


st / lo 


< 


alhost / student / useri 


nfo | phpEyAdain 2- 


编 格 下) Ez 收 豪 W) 工具 中 帮助 只 


四 国 的 局 mr 克 x 如 人 犁 


hp 


已 经 有 info 


口 username varchar(20) gb2312_chinese_ci 


各 | 区 


student 2) 


student (2) 


国 info 


国 userinfo 


至 此 ， 本 实例 制作 完成 。 


练习 


口 userimg 
?一 全 选 / 全 部 不 选 次 力 页 国庆 XX 


口 userpass varchar(20) gb2312_chinese_ci 
varchar (50) gb2312_chinese_ci 


加 四 喝 


名 打印 预览 器 规划 表 结 构 @ 
屠 添 加 i1 
usemame 司 之 后 攻 梧 


字段 @ 于 表 结 尾 O 〇 于 表 开 头 O 于 


图 4.18” 表 创建 成 功 


1. 常用 的 SQL 语句 有 哪些 ?如 何 对 查询 结果 进行 排序 ? 


各 
3. 
所 示 。 


在 MySQL 中 


新 增 


-个 用 户 有 几 种 方法 ? 
分 别 用 SQL 语句 和 phpMyAdmin 创建 表 register， 其 中 


表 4.3 register 表 中 字段 的 基本 情况 


分 别 如 何 操作 ? 


各 字段 的 基本 情况 如 表 4.3 


所 和光 
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ss 
PHP+MySQL 编程 


> PHP 与 MySQL 数据 库 的 连接 

> PHP 操作 MySQL 数据 库 的 原理 与 方法 
> PHP 实现 数据 分 页 的 方法 

> 用 MySQL 改写 用 户 注册 与 登录 程序 


> 掌握 PHP 与 MySQL 数据库 的 连接 

> 掌握 PHP 操作 MySQL 数据库 的 原理 与 方法 并 实际 操作 
> 用 PHP 实际 操作 数据 分 页 

> 掌握 用 MySQL 改写 用 户 注 册 与 登录 程序 


教学 基础 要 求 
> 掌握 PHP 与 MySQL 数据 库 的 连接 

> 了 解 PHP 操作 MySQL 数据 库 的 原理 与 方法 并 实际 操作 
> 了解 PHP 实现 数据 分 页 

六 “掌握 用 MySQL 改写 用 户 注册 与 登录 程序 


任务 “PHP 其 作 MySQL 数据 血 


任务 描述 


回 ”掌握 PHP 操作 MySQL 数据 库 的 流程 
回 了 解 常用 PHP 数据 库 函 数 

回 ”完成 对 数据 的 插入 、 删 除 和 修改 

回 PHP 数据 分 页 的 实现 


知识 汇总 
S.1.1 准备 连接 数据 库 


经 过 前 面 的 学 习 , 现在 终于 要 迈 入 PHP+MySQL 数据 库 编 程 的 大 门 了 。 不 过 在 此 之 前 ， 
还 有 最 后 一 个 问题 要 注意 , 那 就 是 做 好 连接 数据 库 前 的 准备 工作 ,否则 可 能 无 法 连接 成 功 。 

从 PHP 5 开始 ，PHP 开发 者 放弃 了 对 MySQL 的 默认 支持 , 而 是 放 到 了 扩展 函数 库 中 。 
因此 要 使 用 MySQL 函数 ， 首 先 需 要 开启 MySQL 函数 库 。 

打开 php.ini， 找 到 代码 行 :extensions=php_mysql.dll， 将 此 行 前 面 的 分 号 “;” 去 掉 ， 保 
存 之 后 重新 启动 IS/Apache。 这 时 仍然 不 能 肯定 这 些 函 数 已 经 被 载 入 ， 可 以 通过 phpinfo() 
函数 来 查看 。 用 phpinfo0 函 数 显 示 出 PHP 环境 配置 信息 ， 然 后 查找 里 面 是 否 有 一 个 名 为 
MySQL 的 项 目 。 如 果 能 找到 ， 则 说 明 PHP 已 经 完全 开启 了 对 MySQL 的 支持 ,可 以 在 程序 
中 直接 调用 MySQL 数据 库 ， 如 图 5.1 所 示 。 


hon ro tern Pplorer 
文件 于 )】 ”编辑 下 ) ”查看 G) 收 藤 由 ) 工具 0) 帮助 0 
四 鲁 - 轩 - 国 国 的 用 四 讽 smx 已 全 -你 画 - 回 级 总 


雹 址 加 ) 者 http://1ocalhost/phpsource/chspt08/test php v | 图 R 到 ts > 


图 5.1 开启 MySQL 函数 库 
如 果 此 时 不 能 显示 MySQL 的 信息 ， 说 明 配 置 还 没有 成 功 。 除 了 继续 检查 上 一 步 修改 RS 


合 一 一 . aaw 5- wnt 


a … 项 目 5 PHP+MySQL 编程 图 i 


是 否 正 确 以 外 ， 可 以 把 PHP 安装 目录 下 的 libmysql.dll 库 文件 直接 复制 到 系统 的 system 目 
录 或 者 system32 目录 下 。 复 制 之 后 再 重新 启动 IS/Apache， 这 时 再 次 运行 phpinfo() 程 序 ， 
看 是 否 出 现 了 MySQL 信息 。 一 般 来 说 ， 复 制 ibmysql.dll 是 最 有 把 握 的 一 种 方法 ， 正 常情 
况 下 可 以 成 功 。 

如 果 反 复 重 复 上 述 步骤 仍然 不 能 成 功 开启 MySQL 函数 库 ， 有 可 能 是 PHP 安装 包 不 完 
整 或 计算 机 的 软件 环境 有 问题 。 可 以 通过 正规 渠道 重新 下 载 PHP 安装 包 , 并 重新 配置 PHP， 
或 者 整理 计算 机 的 软件 环境 来 解决 。 


5.1.2 PHP 操作 MySQL 的 原理 


PHP 是 一 门 Web 编程 语言 ， 而 MySQL 是 一 款 网 络 数据 库 系 统 ， 二 者 是 目前 Web 开发 
中 的 黄金 组 合 之 一 。 那么 PHP 是 如 何 操作 MySQL 数据 库 的 ? 只 有 对 PHP 操作 MySQL 数 
据 库 的 流程 有 一 个 基本 了 解 ， 才 能 更 加 准确 地 理解 PHP 数据 库 编程 的 思路 ， 为 后 面 的 学 习 
打下 基础 。 

从 根本 上 来 说 ，PHP 通过 预先 写 好 的 一 系列 函数 来 与 MySQL 数据 库 进 行 通信 ， 向 数 
据 库 发 送 指令 、 接 收 返回 数据 等 都 通过 函数 来 完成 ， 如 图 5.2 所 示 为 一 个 普通 PHP 程序 与 
MySQL 进行 通信 的 基本 原理 示意 图 。 


MySQL 数据 库 服务 器 


PHP PHP 
程序 函数 


图 5.2 PHP 程序 与 MySQL 数据 库 通信 原理 示意 图 


图 5.2 展示 了 PHP 程序 连接 到 MySQL 数据 库 服 务 器 的 原理 。 可 以 看 出 ，PHP 通过 调 
用 自身 的 专门 用 来 处 理 MySQL 数据 库 连接 的 函数 ,来 实现 与 MySQL 通信 ,在 操作 过 程 中 ， 
PHP 并 不 是 直接 操作 数据 库 中 的 数据 ， 而 是 把 要 执行 的 操作 以 SQL 语句 的 形式 发 送 给 
MySQL 服务 器 ， 由 MySQL 服务 器 执行 这 些 指令 ， 并 将 结果 返回 给 PHP 程序 。MySQL 数 
据 库 服务 器 可 以 比 作 一 个 数据 “管家 ”。 其 他 程序 需要 这 些 数据 时 ， 只 需要 向 “管家 ”提出 
请 求 ,“ 管 家 ”就 会 根据 要 求 进行 相关 的 操作 或 返回 相应 的 数据 。 
Wh 从 PHP 代码 到 最 终 取 得 数据 的 流程 如 图 5.3 所 示 。 
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浏览 /创建 数据 库 


PHP 代 码 


删除 /修改 数据 库 


| 和 和 /gl 建 才 | [er rem | | 删除 (性 改 表 | 


返回 操作 结果 


关闭 数据 库 连接 


图 5.3 PHP 操作 MySQL 数据 库 流程 

明白 了 PHP 操作 MySQL 数据 库 的 流程 ,就 很 容易 掌握 PHP 操作 MySQL 的 相关 函数 。 
因为 流程 中 每 一 个 步骤 ， 几 乎 都 有 相应 的 函数 与 之 对 应 。 开 发 PHP 数据 库 程 序 时 ， 只 需要 
按照 流程 调用 相关 函数 ， 便 可 轻松 实现 数据 库 操 作 。 


5.1.3 PHP 操作 MySQL 的 方法 


PHP 提供 了 大 量 函 数 ， 使 用 户 可 以 方便 地 使 用 PHP 连接 到 MySQL 数据 库 ， 并 对 数据 
进行 操作 。 学 习 PHP+MySQL 数据 库 编程 ， 首 先 要 了 解 这 些 函 数 ， 明 确 具 体 的 步 又， 然后 


才能 进入 实质 性 开发 阶段 。 


PHP 中 可 以 用 来 操作 MySQL 数据 库 的 函数 如 表 5.1 所 示 。 


函 数 名 


Inysql_affected rows 


表 5.1 PHP 的 MySQL 数据 库 操作 函数 


功 能 
取得 前 一 次 MySQL 操作 所 影响 的 记录 行 数 


mysql change user 
mysql_client_ encoding 


mysql_close 


改变 活动 连接 中 登录 的 用 户 


返回 字符 集 的 名 称 
关闭 MySQL 连接 


Inysql_ connect 


打开 一 个 到 MySQL 服务 器 的 连接 


mysql_create db 


新 建 一 个 MySQL 数据库 


Imysql data_seek 移动 内 部 结果 的 指针 
mysql_ db _ name 取得 结果 数据 


mysql db query 


发 送 一 条 MySQL 查询 


mysql drop db 


mysql ermo 


丢弃 (删除 ) 一 个 MySQL 数据 库 


返回 上 一 个 MySQL 操作 


bh 错误 信息 的 数字 编码 


mysql error 


返回 上 一 个 MySQL 操 


生 的 文本 错误 信息 


mysql fetch array 


从 结果 集中 取得 一 行 作为 关联 数组 或 数字 数组 ， 或 二 者 兼 有 


‘1 
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函 数 名 
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Inysql fetch assoc 


mysql] fetch field 


从 结果 集中 取得 一 行 
从 结果 集中 取得 列 信息 并 作为 对 象 返回 


mysql fetch lengths 


取得 结果 集中 每 个 输出 的 长 度 


mysql fetch object 


mysql fetch row 


从 结果 集中 取得 一 行 作为 对 象 
从 结果 集中 取得 一 行 作为 枚 举 数组 


Iysql field flags 


从 结果 中 取得 和 指定 字段 关联 的 标志 


mysql field len 
mysql field name 


mysql field seek 


返回 指定 字段 的 长 度 
取得 结果 中 指定 字段 的 字段 名 
将 结果 集中 的 指针 设 定 为 指定 的 字段 偏 移 量 


Imysql field_table 


取得 指定 字段 所 在 的 表 名 


Imysql field_ type 
mysql free result 


mysql get client info 


mysql_get host_info 


mysql_get proto_info 
mysql get server info 
mysql_info 
mysql_insert id 
mysql_ list_dbs 
mysql list_ fields 
mysql_list_processes 
mysql list_tables 


mysql num fields 


取得 结果 集中 指定 字段 的 类 型 
释放 结果 内 存 


取得 MySQL 服务 器 人 

取得 最 近 一 条 查询 的 人 

取得 上 一 步 INSERT 慎 :的 ID 
列 出 MySQL 服务 器 中 所 有 的 数据 库 
列 出 MySQL 结果 中 的 字段 

列 出 MySQL 进程 

列 出 MySQL 数据 库 中 的 表 

取得 结果 集中 字段 的 数目 


mysql num rows 


取得 结果 集中 行 的 数目 


Inysql pconnect 打开 一 个 到 MySQL 服务 器 的 持久 连接 

mysql ping Ping 一 个 服务 器 连接 ， 如 果 没 有 连接 则 重新 连接 
Inysql query 发 送 一 条 MySQL 查询 

Imysql_ result 取得 结果 数据 

Imysql select db 选择 MySQL 数据 库 

Inysql stat 取得 当前 系统 状态 

Imysql tablename 取得 表 名 

mysql thread id 返回 当前 线程 的 了 D 


这 些 函 数 中 ， 最 常用 的 有 mysql_connectD、mysql_select_db0、mysql_queryO、mysql_ 


\Y / fetch aray0)、mysql num rows()、mysql close(0) 等 ， 下 面 将 着 
Wg. 


过 高 等 职业 教育 “十 二 五 " 规划 教材 


介绍 其 中 几 个 函数 的 使 用 。 


5.1.4 用 PHP 操作 MySQL 数据 库 


1. mysql connectO 函 数 

根据 图 5.3 所 示 的 流程 ， 要 用 PHP 操作 MySQL 中 的 数据 ， 第 一 步 就 是 连接 到 数据 库 
服务 器 ， 也 就 是 建立 一 条 PHP 程序 到 MySQL 数据 库 之 间 的 通道 。 这 样 ，PHP 才能 通过 这 
个 通道 来 向 MySQL 服务 器 发 送 各 种 指令 , 并 取得 指令 执行 的 结果 , 将 这 些 结果 应 用 于 PHP 
程序 中 。mysql_connect0 函 数 就 是 用 来 建立 和 MySQL 数据库 的 连接 的 。 

mysql_connect(0) 函 数 有 5 个 参数 ， 但 是 通常 情况 下 只 用 前 3 个 参数 ， 其 格式 如 下 : 


resource mysql_connect (string server, string username, string password) 


该 函数 返回 类 型 为 resource 型 ， 即 资源 型 。3 个 参数 分 别 为 MySQL 服务 器 地 址 、 
MySQL 用 户 名 、 密 码 。 这 里 的 用 户 名 可 以 是 超级 管理 员 的 ， 也 可 以 是 用 户 表 中 存在 的 其 他 
用 户 。 如 下 面 的 语句 将 用 超级 管理 员 身 份 建立 一 个 到 本 地 服务 器 的 连接 : 


S$id=mysql_connect ("localhost","root","root"); 


其 中 localhost 换 成 127.0.0.1 或 本 地 机 器 的 实际 人 P 地 址 ， 效 果 都 是 相同 的 。 另 外 ， 服 
务 器 地 址 后 面 可 以 指定 MySQL 服务 的 端口 号 , 如 果 是 采用 默认 的 3306 端口 , 则 不 必 指 定 。 
如 果 采 用 了 其 他 端口 ， 则 需要 指定 ， 如 127.0.0.1:88 表示 MySQL 服务 于 本 地 机 器 的 88 端 
口 。 用 户 名 和 密码 均 需 指定 (如 密码 为 空 ， 则 直接 用 两 个 引号 即 可 )。 

将 以 上 代码 写 在 一 个 PHP 程序 中 ， 写 法 如 下 : 


<2php 
S$id=mysql_connect("localhost","root","root"); 
echo $id; 
‘> 
此 程序 运行 之 后 , 如 果 执 行 成 功 , 则 会 输出 一 个 资源 型 变量 $id 的 编号 , 类 似 于 Resource 


id # 可 ;如 果 执行 失败 ， 则 有 多 种 可 能 。 如 果 出 现下 列 提 示 : 

Fatal error: Call to undefined function mysql_connect in[...... ] 

则 说 明 本 地 服务 器 的 MySQL 扩展 库 尚未 被 载 入 ， 因 此 PHP 解释 器 无 法 识别 MySQL 
函数 ， 可 参照 5.1.1 节 的 内 容 进 行 重新 设置 。 

如 果 出 现下 列 提 示 : 


Warning: mysql_connect() [function.mysql-connect]: Unknown MySQL server host [...] 

则 说 明 MySQL 服务 器 地 址 错误 ， 可 能 是 输入 有 误 、 服 务 器 没有 启动 ， 或 端口 号 不 正 
确 。 这 时 可 以 检查 函数 的 第 一 个 参数 是 否 提 供 正确 ，MySQL 是 否 已 成 功 启动 。 

还 有 可 能 出 现下 列 提示 : 


Warning: mysql_connect() [function.mysql-connect]: Access denied for user [...] 


\ 


‘1 


-高 等 职业 教育 “十 二 五 ”规划 教材 一 S 


四 多 一 高等 职业 教育 “十 二 五 ”规划 教材 


\ 


/ 


ee 项 目 5 PHP+MySQL 编程 国 


这 说 明 用 户 名 或 密码 有 错误 ， 或 者 本 账号 没有 在 MySQL 服务 器 上 登录 的 权限 。 


这 里 之 所 以 如 此 详细 地 讲解 该 函数 ， 就 是 因为 这 是 连接 到 MySQL 数据 库 的 第 一 步 。 
只 要 这 一 步 成 功 了 ， 下 面 的 函数 便 都 能 运行 。 连 接 到 数据 库 是 一 切 工作 的 起 点 ， 因 此 必须 


保证 此 步骤 成 功 ， 才 能 继续 下 面 的 内 容 。 
2. mysql_select_db() 浮 数 


连接 到 数据 库 以 后 ， 还 不 能 直接 操作 某 个 表 ， 因 为 表 都 存储 在 各 个 数据 库 中 ， 需 要 首 
先 选择 要 操作 的 数据 库 ， 才 能 对 这 个 数据 库 中 的 表 进 行 操作 。mysql_select db0 函 数 就 用 来 
指定 操作 的 数据 库 。 前 面 的 例子 中 曾 在 MySQL 中 创建 了 一 个 student 数据 库 ， 下 面 的 代码 


将 连接 到 数据 库 服务 器 ， 并 把 student 数据 库 作为 当前 要 操作 的 数据 库 。 
【 例 5.1】 


<! 一 程序 5.1.php: 连接 数据 库 服务 器 ， 选 择 数 据 库 --> 
<html> 

<head> 

<title> 连 接 数 据 库 服务 器 ， 选 择 数 据 库 </title> 

</head> 

<body> 

<?php 

$id=mysql_connect("localhost","root","root'); 

if ($id){ 

echo "OK， 数 据 库 连接 成 功 ! <br>"; 

$ok=mysql_select_ db("student",$id): 

这 $ok){ 

echo "OK， 选 择 数 据 库 成 功 !"; 

j}else{ 

echo "OH， 选 择 数据 库 失 败 ， 请 确认 数据 库 是 否 存在 。"; 
}else{ 

echo "OH， 数 据 库 连接 失败 ! 请 检查 服务 器 地 址 、 用 户 名 和 地 址 是 否 正确 ! 


<br>"; 


} 

?> 
</body> 
</html> 


本 程序 第 8 行 建立 了 一 个 到 本 地 MySQL 数据 库 服 务 器 的 连接 。 第 11 行 用 mysql_select_ 


db0 函 数 来 指定 要 操作 的 数据 库 。 函 数 第 一 个 参数 为 数据 库 的 名 字 ， 第 二 个 参数 为 应 月 


日 于 


哪个 连接 。 第 二 个 参数 可 以 省 略 ， 省 略 时 默认 使 用 当前 连接 。 一 般 来 说 ， 此 参数 可 以 直接 


省 略 。 


Imysql select_ db0 函 数 返回 一 个 布尔 型 值 。 如 果 执 行 成 功 返 回 TRUE， 失 败 则 返回 
FALSE。 函 数 没有 任何 错误 信息 提示 。 因 此 即使 提供 的 数据 库 名 有 错误 或 数据 库 不 存在 ， 


本 函数 也 不 会 报错 。 程 序 将 返回 结果 存放 在 Sok 中 , 通过 判断 $ok 的 值 来 判断 是 否 执行 成 
程序 5.1.php 正确 执行 的 效果 如 图 5.4 所 示 。 


功 。 


文件 四 ”编辑 中 查看 收 训 和 工具 中 和 助 o0 


~ A 
Gs- 日 着 国 的 记 ar 克 wmx 加 加 
地 让 @) | 阐 http://1ocslhost/phpsource/chapt08/8-1. php ~ 加 WI asE >” 


OK, 数据 库 连 接 成 功 ! 
OFK, 选择 数据 库 成 功 ! 


图 5.4 程序 5.1.php 正确 运行 的 结果 
3. mysql queryO) 函 数 
连接 到 数据 库 服务 器 并 选择 了 要 操作 的 数据 库 之 后 ， 就 要 向 服务 器 发 送 操作 指令 ， 即 
SQL 语句 了 。 下 面 来 看 一 个 例子 ， 用 PHP 程序 在 MySQL 中 创建 一 个 数据 库 newdata， 并 
在 这 个 数据 库 中 创建 一 个 表 testtable， 表 的 字段 可 以 随意 设置 几 个 。 
【 例 5.2】 


<! 一 程序 5.2.php: 用 PHP 创建 新 数据 库 和 表 --> 

<html> 

<head> 

<title> 用 php 创建 新 数据 库 和 表 </title> 

</head> 

<body> 

<2php 

if (!$id=mysql_connect("localhost","root","root")){ 

echo "数据 库 服务 器 连接 错误 !"; 

exit; // 如 果 数 据 库 服务 器 连接 不 成 功 ， 退 出 程序 执行 
} 

echo "数据 库 服务 器 连接 成 功 ! <br>"; 

if (Imysql_query("CREATE DATABASE newdata",$id)){ 

echo" 数 据 库 创建 不 成 功 ， 请 检查 账号 权限 和 数据 库 是 否 已 经 存在 !"; 

exit; // 如 果 数 据 库 创建 不 成 功 ， 退 出 程序 执行 


} 

echo "数据 库 创 建成 功 ! <br>"; 

if (Imysql_select_db("newdata",$id)){ 

echo "数据 库 选 择 不 成 功 !"; 

exit; // 如 果 数 据 库 选择 不 成 功 ， 退 出 程序 执行 


} 

echo "数据 库 选 择 成 功 ! <br>"; 

if (Imysql_query("CREATE TABLE testtable (name varchar(10), age int(4))",$1d)){ 

echo "数据 表 创建 不 成 功 ， 请 检查 SQL 语句 是 否 正 确 ! "; 

exit; // 如 果 SQL 执行 不 成 功 ， 退 出 程序 执行 


} 

echo "数据 表 创 建成 功 ! <br>"; 

if (mysql_close($i1d)){ 

echo "数据 服务 器 连接 关闭 成 功 !"; 

要 

</body> 

</html> NI 
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本 程序 正确 执行 的 效果 如 图 5.5 所 示 ， 再 次 刷新 后 的 执行 效果 如 图 5.6 所 示 。 


钮 用 PHP 创 建新 数据 库 和 表 - Hicrosoft Internet Exp... 蒜 | 呈 | 区 

文件 中 编辑 查看 WD 收 送 人) 工具 GD) 帮助 0 本 

Oa- 四 加 多 时 南 tax @ .| 全 且 本 
文件 FE) 六 辑 于 ) 查看 WW) 收 燕 和) 工具 CI) 才 助 0D) 

Oi- © OP wm © DO" 
诸 广 0) 乱 http://1ocalhost/phpsource/chapt08/8-2.php 清 


选择 成 功 
和 加 人 | 数据 库 服务 器 连接 成 功 | 
数据 服务 器 连接 关闭 成 功 ! 数据 库 创建 不 成 功 ， 请 检查 账号 权限 和 数据 库 是 否 已 经 存在 1 


暂 http: //1ocalhost/php: /chapt08/8-2.php | 回转 到 这 后” 


数据 库 服务 器 连接 成 功 | 
数据 库 创建 记功 


本 地 Intranet 
图 5.5 程序 5.2.php 正确 运行 的 结果 图 5.6 程序 5.2.php 第 二 次 运行 的 结果 


程序 5.2.php 的 输出 结果 已 经 详细 说 明了 创建 数据 库 和 数据 表 的 基本 步骤 , 程序 中 注释 
也 说 明了 每 条 语句 的 作用 ， 这 里 就 不 再 袭 述 。 如 果 用 phpMyAdmin 或 前 面 讲 过 的 命令 提示 
符 进 入 MySQL 控制 台 , 就 会 发 现 已 经 成 功 创建 了 一 个 名 为 newdata 的 数据 库 。 打 开 此 数据 
库 ， 可 以 看 到 数据 库 中 有 一 个 testtable 表 。 也 就 是 说 程序 执行 的 不 仅仅 是 输出 结果 成 功 ， 
而 是 真正 的 成 功 。 

通过 程序 可 以 看 出 mysql_query0 函 数 的 使 用 十 分 简单 , 只 需要 将 一 条 SQL 语句 作为 参 
数 传递 过 去 ， 即 可 执行 此 SQL 语句 。 第 二 个 参数 $id 在 一 般 情况 下 同样 可 以 省 略 。 

使 用 mysql_query0 函 数 可 以 向 数据 库 服务 器 发 送 任何 合法 的 SQL 指令 (前 提 是 数据 库 
要 支持 该 指令 )。 程 序 5.2.php 只 是 测试 了 CREATE 指令 ， 实际 上 前 面 讲 到 的 INSERT、 
SELECT、UPDATE、DELETE 等 指令 同样 可 以 用 mysql_query0 来 执行 。 下 面 就 利用 循环 
向 服务 器 发 送 多 次 INSERT 指令 ， 向 刚才 创建 的 testtable 表 中 插入 多 条 记录 。 

【 例 5.3】 

<! 一 程序 5.3.php: 用 PHP 向 表 中 插入 数据 --> 

<html> 

<head> 

<title> 用 php 向 表 中 插入 数据 </title> 

</head> 

<body> 

<2php 

$id=mysql_connect("localhost","root","root"):; 

mysql_select_db("newdata",$id); 

for($i=1:;$1<6;$i++){ 

$nl=20+$1i; 

Sxm=" 姓 名 ".$i; 

$sql="INSERT INTO testtable VALUES(" .$xm.",".$n1.")"; 

S$excu=mysql_query($sql,$id): 


if($excu){ 

echo $sql; 

echo "第 ".$i." 条 数据 插入 成 功 ! <br>"; 

}else{ 

echo "数据 插入 失败 ， 错 误 信息 : <br>"; 

echo mysql_eror0; // 输 出 上 一 次 MySQL 执行 的 错误 信息 


mysql_close($id); 
?> 

</body> 

</html> 


为 了 简化 程序 代码 ， 程 序 5.3.php 的 第 8 一 9 行 数据 库 服务 器 的 连接 、 数 据 库 的 选择 没 
有 再 进行 正确 性 验证 。 程 序 5.3.php 的 运行 结果 如 图 5.7 所 示 。 


下 用 PHP 向 表 中 插入 数据 ， 
文件 中 ”编辑 是 ) 查看 中” 收 意 @) 工具 上 帮助 o) 


四 刍 - 加- 回国 的 万 闻 丙 sx 加 隔日 - 


地 泪 0 | 四 http://1ocalhost/php5_book/ chap3/9-3. php v 图 9 到 WW ” 


INSERT INTO testtable VALUES( 姓名 3 ， 23) 第 3 条 数据 
INSERT INTO testtable VALUES( 姓名 4 ,24) 第 4 条 数据 插入 成 功 | 
INSERT INTO testtable YALUES( 姓名 5 25) 第 5 条 数据 插入 成 功 1 


本 ET 


图 5.7 程序 5.3.php 的 运行 结果 


要 验证 5 条 记录 是 否 都 已 确实 插入 到 了 数据 库 中 ， 可 以 用 命令 提示 符 登 录 控 制 台 ， 用 
SELECT * FROM testtable 命令 来 浏览 表 中 的 所 有 数据 ， 也 可 以 用 phpMyAdmin 来 浏览 。 
控制 台中 显示 的 数据 如 下 : 


mysql> select * from testtable; 
和 十 ------ 十 


|name | age | 


| 姓名 4| 24 

| 姓名 5| 25 
+- 一 -一 十 -一 一 十 

5 rows in set (0.00 sec) 


可 见 数据 确实 已 经 成 功 插入 到 数据 库 中 。 

程序 5.3.php 看 起 来 行 数 较 多 , 但 是 其 结构 却 很 简单 .读者 可 以 根据 所 学 知识 分 析 一 
在 这 里 仅 指出 3 点 。 

(1) 第 11 一 12 行将 要 插入 的 两 个 字段 的 值 放 在 两 个 变量 中 , 然后 在 第 13 行 构造 一 个 
SQL 语句 ， 第 14 行 执行 这 个 语句 。 这 里 之 所 以 采用 变量 存放 字段 值 和 SQL 语句 ， 一 是 为 
了 使 程序 更 加 易 读 ， 另 外 可 以 避免 写成 一 条 综合 语句 过 于 复杂 而 容易 出 错 。 读 者 尤其 要 注 
意 第 13 行 ， 在 构造 SQL 语句 〈 其 实 就 是 一 个 普通 字符 串 ) 时， 不 同 数据 类 型 的 变量 用 不 
| 号 连接 。 其实 该 问题 是 一 个 PHP 基本 语法 的 问题 , 很 多 初学 者 容易 在 这 个 地 方 出 错 ， 

请 读者 多 加 揣摩 ， 仔 细 体 会 。 
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(2) 第 20 行 首次 使 用 mysql_error0 函 数 。 该 函数 可 以 返回 上 一 次 MySQL 返回 的 错误 
信息 。 当 程序 出 错时 输出 这 些 错 误 信 息 对 于 程序 的 调试 很 有 帮助 。 读 者 可 以 试 着 故意 写 错 
SQL 语句 ， 或 者 故意 发 送 一 条 非法 指令 到 MySQL 服务 器 ， 然 后 调用 此 函数 查看 返回 的 错 
误 信 息 。 

(3) 如 果 插 入 数据 后 出 现 了 乱码 ， 则 需要 设置 相关 的 编码 ， 因 为 这 里 采用 的 是 默认 编 
码 ， 即 Latinl 字符 集 ， 所 以 省 略 了 向 数据 库 发 送 SET CHARACTER 指令 。 如 果 数 据 库 服 
务 器 设置 的 是 gb2312 字符 集 ， 必 须 在 第 9 行 后 加 入 mysql_query("SET CHARACTER SET 
gb2312"); 进 行 字符 设置 。 这 条 指令 与 程序 功能 无 关 ， 是 否 加 入 该 语句 以 及 具体 设置 什么 样 
的 字符 集 与 服务 器 采用 的 MySQL 版 本 以 及 安装 MySQL 时 的 设置 有 关 。 而 且 值 得 注意 的 是 ， 
插入 时 进行 了 字符 的 设置 ， 从 数据 库 中 读 出 数据 时 也 必须 进行 同样 的 设置 ， 否 则 就 会 出 现 
乱码 。 

下 面 再 来 看 一 个 从 数据 库 中 读 取 数据 并 用 表格 显示 在 网 页 上 的 例子 。 还 是 用 mysql_ 
query0 函 数 ， 向 数据 库 发送 SELECT 指令 来 查询 数据 。 

【 例 5.4】 


<!-- 程 序 5.4.php: 用 PHP 从 表 中 读 取 数 据 --> 
<html> 

<head> 

<title> 用 php 从 表 中 读 取 数 据 </title> 

</head> 

<body> 

<2php 
Sid=mysql_connect("localhost","root", "root"); 
mysql_select_db("newdata",$id); 

$query="SELECT * FROM testtable"; 
$result=mysql_query($query,$id); 
$datanum=mysql_num rows(S$result); 

echo " 表 testtable 中 共有 ".$datanum." 条 数据 <br>"; 
?> 

<table width="228" height="34" border="1"> 

<2php ”while ($info=mysql fetch amay(Sresult MySQL ASSOC){ ?> 
<tr> 

td width="99" height="28"><?php echo $info["name"]?> </td> 
<td width="113"><?php echo $info["age"]?></td> 
</tr> 

<2php }2> 

</table> 

<2php mysql_close($1d):?> 

</body> 

</html> 


程序 5.4.php 的 输出 结果 如 图 5.8 所 示 。 
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沪 用 PHP 从 表 中 该 取 数据 - Hicrosoft Internet Explorer 尾 站 |] 必 ] 
文件 四 ”六 辑 E) 查看 WD 收 若 内 工具 四 帮助 0D E33 


@se- 日 四国 的 Per 克 tmx @ 全 


增 址 中) | 乔 http://1ocalhost/phpsowree/chspt08/8-4.php 回国 苇 到 证” 


表 testtable 中 共有 5 条 数据 
姓名 1 21 
姓名 2 22 
姓名 3 23 
姓名 4 24 
姓名 5 25 


图 5.8 程序 5.4.php 的 运行 结果 


程序 5.4.php 在 代码 中 加 入 了 一 些 HTML 代码 ， 用 来 产生 一 个 表格 。 程 序 又 用 到 了 几 
个 新 的 函数 ， 下 面 就 来 一 一 介绍 。 

(1) 第 10 行 中 ， 向 服务 器 发 送 了 一 条 SELECT 指令 。 该 指令 将 返回 所 有 满足 条 件 的 
记录 。 注 意 返 回 的 记录 是 一 个 资源 类 型 ， 其 内 容 是 若干 条 记录 的 集合 ， 可 以 成 为 一 个 记录 
集 ， 不 能 直接 用 来 输出 ， 先 将 返回 的 数据 存放 在 $result 中 。 

(2) 第 12 行 ， 用 mysql_num rows0 函 数 来 统计 一 个 记录 集中 记录 的 条 数 。 注 意 此 函 
数 专用 于 统计 MySQL 查询 结果 记录 数 ， 不 能 用 来 统计 其 他 数据 类 型 的 元 素 个 数 。 

(3) 第 16~21 行 ， 充 分 说 明了 PHP 是 一 种 嵌入 式 脚 本 语言 。 读 者 要 养 成 一 个 好 的 习惯 ， 
就 是 当 有 PHP 和 HTML 代码 混合 时 尽量 把 PHP 代码 嵌入 到 HIML 中 ， 这 样 在 网 页 可 视 化 的 编 
辑 工具 〈 如 Dreamweaver) 中 就 可 以 很 好 地 把 PHP 代码 和 网 页 界面 分 离开 ， 便 于 编辑 。 

(4) 第 16 行 是 关键 ， 这 一 行 用 到 了 mysql fetch array0 函 数 。 此 函数 是 PHP+MySQL 
编程 中 最 常用 的 函数 之 一 。 其 格式 如 下 : 


array mysql_fetch_array (resource result [, int result_type]) 


该 函数 的 作用 是 读 取 记录 集 result 中 的 当前 记录 ， 将 记录 的 各 个 字段 的 值 存 入 一 个 数 
组 中 ， 并 返回 这 个 数组 ， 然 后 将 记录 集 指针 移动 到 下 一 条 记录 。 如 果 记 录 集 已 经 到 达 末 尾 ， 
则 返回 FALSE。 

第 2 个 参数 result_ type 为 可 选 参数 ， 用 来 设置 返回 的 数组 采用 什么 样 的 下 标 。 有 3 个 
备 选 值 : MySQL ASSOC、MySQL NUM、MySQL BOTH， 其 含义 如 下 。 

@ MySQL ASSOC: 返回 的 数组 将 以 该 记录 的 字段 名 称 作为 下 标 。 如 在 本 例 中 要 输出 
此 数组 中 的 “姓名 ”字段 ， 可 以 用 $info["name"]。 这 里 $info 是 数组 名 ，name 是 存放 姓名 的 
字段 名 。 

加 MySQL NUM: 返回 的 数组 以 从 0 开始 的 数字 为 下 标 。 在 本 例 中 , 返回 的 每 条 记录 
只 有 两 个 字段 ， 那 么 数组 也 就 只 有 两 个 元 素 ， 分 别 用 $info[0]、$info[1] 来 引用 。 

@ MySQL BOTH: 返回 的 数组 既 可 以 用 字段 名 为 下 标 ， 也 可 以 用 数字 为 下 标 。 在 本 
例 中 ， 既 可 以 用 $info[0] 来 取得 姓名 ， 也 可 以 用 $info["name"] 来 取得 。 

读者 可 以 自行 修改 程序 ， 对 上 述 3 个 参数 进行 测试 。 
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此 外 ，PHP 中 还 有 mysql_fetch_rowO、mysql fetch assoc()、mysql fetch_object() 等 函 
数 ， 这 些 函 数 的 作用 与 用 法 都 和 mysql_fetch_array0 函 数 相似 ， 读 者 可 以 参考 PHP 手册 ， 


了 解 这 几 个 函数 的 使 用 。 

用 mysql_query0 函 数 ,结合 讲 过 的 SQL 语句 , 还 可 以 轻松 实现 对 表 内 数据 的 删除 和 修 
改 ， 如 : 

<?php 


S$id=mysql_connect("localhost","root","1234"); 
mysql_select_db("newdata",$1d); 
mysql_query("DELETE FROM testtable", $id); 
mysql_close($id); 

?> 


这 段 程 序 执行 后 ， 会 删除 表 testtable 中 的 全 部 数据 。 

此 外 ,用 UPDATE 语句 可 以 实现 对 表 内 数据 的 修改 ， 这 里 不 再 举例 ， 读 者 可 以 自行 编 
写 程序 练习 。 

4，mysql closeO 函 数 

mysql_close() 函 数 用 来 关闭 一 个 数据 库 连 接 ， 其 格式 如 下 : 


bool mysql_close ( [resource link identifier] ) 


本 函数 只 有 一 个 可 选 参数 link_identifier。 此 参数 表示 要 关闭 的 连接 的 ID 。 也 就 是 
mysql_connect() 函 数 执行 成 功 后 返回 的 一 个 连接 标记 。 参 数 为 空 时 表示 关闭 当前 连接 。 该 
函数 返回 一 个 布尔 型 结果 。 当 关闭 成 功 时 返回 TRUE， 关 闭 失败 时 返回 FALSE。 例 如 : 


<?php 
$id=mysql_connect("localhost","root","1234"); 
这 mysql_close($id)){ 
echo" 关 闭 数据 库 连 接 成 功 !"; 
j}else{ 
echo" 关 闭 数据 库 连接 失败 !"; 
} 


2 


上 面 的 代码 演示 了 mysql_close0 函 数 的 使 用 。 事 实 上 ， 当 一 个 PHP 脚本 (也 就 是 一 个 
PHP 页 面 以 及 它 的 包含 文件 ) 执行 结束 时 ， 该 脚本 中 打开 的 PHP 连接 也 会 同时 被 关闭 。 因 
此 一 般 情况 下 即使 忘记 手工 关闭 也 没有 关系 。 但 是 数据 库 使 用 完毕 后 关闭 连接 是 一 个 很 好 
的 编程 习惯 。 


5.1.5 在 PHP 中 实现 数据 分 页 
在 Web 开发 中 经 常 遇 到 的 一 个 问题 就 是 对 大 量 数据 进行 分 页 显示 。 如 一 个 留言 板 有 数 


干 条 留言 ， 如 果 这 些 留言 全 都 显示 在 一 个 页 面 上 ， 页 面 将 变 得 很 大 ， 有 时 过 大 的 页 面 还 会 
VY 导致 浏览 器 停止 响应 。PHP 中 提供 了 非常 简单 的 方法 对 数据 进行 分 页 。 
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为 了 更 好 地 说 明 分 页 的 作用 ， 先 向 testtable 表 中 插入 大 量 的 数据 。 修 改 5.3.php， 把 控 
制 插入 条 数 的 for($i=1:$i<6;$i++) 修 改 为 for($i=1:$i<100:Si+tD， 执 行 此 程序 之 后 ， 数 据 库 中 
便 会 插入 99 条 数据 。 这 时 再 运行 5.4.php， 会 发 现 99 条 数据 全 部 显示 在 一 页 内 。 
在 5.4.php 的 基础 上 ， 为 此 程序 增加 分 页 功能 ， 有 具体 如 下 。 
【 例 5.5】 


<!-- 程 序 5.5.php: 用 PHP 实现 数据 分 页 --> 
<html> 

<head> 

<title> 用 php 实现 数据 分 页 </title> 

</head> 

<body> 

<?php 
$id=mysql_connect("localhost","root","root"); 
mysql_select_db("newdata",$id); 
$query="SELECT * FROM testtable"; 
$result=mysql_query($query.,$id); 
$datanum=mysql_num rows(S$result); 

S$page id=$_GET["page id"]; 

if ($page id—""){ 


S$page_ id=1; 

} 

S$page_size="15"; /定义 每 页 显示 条 数 
S$page_num=ceil($datanum/$page_size):; 

> 


表 testtable 中 共有 <?php echo $datanum:?> 条 数据 <br> 

每 页 <?php echo $page_size:?> 条 ， 共 <?php echo $page_num:;?> 页 。<br> 
<2php 

for ($i=1:$i<=$page_nunm:$Si++){ 

echo "[<a href=?page_ id=".$1.">".$1."</a>]"; 

} 

Sstart=($page_1d-1)*$page_size; 

$query2="SELECT * FROM testtable limit $start,$page_size"; 
$result2=mysql]_query($query2.,$1d); 

x 

<table width="228" height="34" border="1"> 

<2php while ($info =mysql fetch array(Sresult?, MySQL ASSOC) { > 
<tr> 

<td width="99" height="28"><?php echo $info["name"]?></td> 
<td width="113"> <?php echo $info["age"]?></td> 

</tr> 

<2php }?2> 

</table> 

<?php mysql_close($1d);?> 

</body> 

</html> 


程序 运行 结果 如 图 5.9 所 示 。 
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表 testtable 中 共有 109 条 数据 
每 页 15 条 ， 共 8 贝 。 


[1][2] [3][4][s][e] [7 [8] 


图 5.9 程序 5.5.php 的 运行 结果 


单 击 不 同 的 页 码 ， 对 应 数据 也 会 随 之 变化 ， 简 单 的 分 页 功能 便 实现 了 。 下 面 对 程 序 
5.5.php 进行 详细 说 明 。 

(1) 第 10 一 12 行 ， 首 先 查询 出 要 显示 的 全 部 数据 的 条 数 ， 放 在 $totalnum 中 。 

(2) 第 13 一 16 行 判断 用 户 是 否 单 击 了 某 一 页 。 通 过 第 13 行 可 以 看 到 ， 当 用 户 单 击 某 
一 个 页 码 时 ， 将 会 把 一 个 页 码 的 数字 作为 参数 传递 给 本 页 面 (用 GET 方法 在 URL 中 传递 
参数 )， 第 14 一 16 行 就 是 判断 是 否 传递 了 这 一 参数 ， 如 果 传 递 了 ， 则 说 明 用 户 选择 了 某 一 
页 ， 这 时 当前 要 显示 的 页 面 就 是 传递 过 来 的 参数 值 。 如 果 参 数 为 宝 ， 则 说 明 本 页 面 直接 被 
打开 ， 用 户 还 没有 选择 某 个 页 面 。 这 时 就 显示 第 一 页 ， 因 此 设置 ypage=1。 

(3) 第 17 行 定义 了 $page_size 变量 ， 将 其 值 设 置 为 13， 即 每 页 显示 15 条 数据 。 

(4) 第 18 行 根据 记录 总 数 和 每 页 显示 的 条 数 计算 出 总 页 数 ， 计 算 方 法 很 简单 ， 这 里 
不 再 分 析 。 此 外 用 到 了 ceil0 函 数 将 计算 结果 进行 进 一 取 整 。 

(5) 第 23 一 25 行 ， 用 循环 输出 了 所 有 页 码 。 每 个 页 面 都 有 一 个 超 链接 ， 单 击 此 超 链 
接 会 将 相应 的 页 码 以 GET 方式 传递 到 本 页 。 

(6) 第 26 行 定义 了 变量 $start， 该 变量 在 第 27 行 的 SQL 语句 中 用 到 。MySQL 支持 在 
SELECT 语句 中 使 用 LIMIT 子 句 ，LIMIT 子 句 的 使 用 方法 为 : 

SELECT* FROM tbl WHERE.......LIMIT [begin].[num] 


此 查询 语句 的 含义 为 ,查询 出 tbl 表 中 满足 指定 条 件 的 全 部 记录 , 然后 只 返回 记录 中 从 
begin 开始 的 num 条 数据 。 也 就 是 说 ,使 用 了 LIMIT 子 句 后 ，MySQL 并 不 返回 所 有 满足 条 
件 的 记录 ， 而 是 只 返回 这 些 记录 中 从 某 条 开始 的 若干 条 。 如 LIMIT 10,5 的 作用 是 取 记 录 集 
中 从 第 10 条 后 的 5 条 ， 即 第 11 一 15 条 记录 。 注 意 这 里 的 计数 是 从 第 1 条 开始 的 。 

这 样 ， 第 26 行 的 $start 就 不 难 理解 了 。 记 录 截 取 起 点 的 计算 方法 为 : 

(要 显示 的 页 码 -1) * 每 页 显示 的 条 数 

如 当前 要 显示 第 3 页 ， 每 页 15 条 ， 那 截取 起 始 位 置 就 是 3-1D)*15=30。 也 就 是 说 ， 第 3 

页 从 第 31 条 数据 开始 显示 ， 连 续 显示 15 条 ， 直 到 第 45 条 。 这 与 实际 情况 相符 。 


(7) 第 31 一 36 行 在 一 个 表格 中 用 while 循环 输出 由 第 27 行 的 SQL 语句 查询 出 的 记录 。 


此 程序 虽然 已 经 实现 了 分 页 功能 ， 但 是 功能 还 不 是 很 完善 。 比 如 本 例 中 全 部 页 码 直 接 


Vx 
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用 循环 列 出 ， 这 样 虽然 很 方便 ， 但 是 在 页 码 很 多 〈 如 几 百 页 ) 的 情况 下 会 使 版 面 混乱 。 可 
以 使 用 “上 一 页 ””“ 下 一 页 ”“ 首 页 ””“ 尾 页 ”等 方法 简化 页 码 显 示 ， 甚 至 可 以 允许 用 户 
输入 跳 转 的 页 数 。 读 者 可 以 根据 所 学 知识 ， 完 善 此 程序 的 功能 。 


5.1.6 PHP 用 户 注 册 与 登录 功能 的 实现 


1. 分 析 

用 户 注册 与 登录 功能 的 实现 有 两 种 方法 : 一 是 把 用 户 的 注册 信息 存放 在 记事 本 中 ， 其 
实 这 样 的 写法 在 现实 的 网 络 中 并 不 常见 ， 二 是 网 络 上 比较 流行 的 用 数据 库 来 存储 用 户 注册 
的 信息 ， 这 是 因为 数据 库 在 存储 和 查询 数据 方面 有 着 记事 本 无 法 比拟 的 优势 ， 当 用 户 登录 
的 时 候 再 与 数据 库 中 的 数据 进行 校 验 ， 如 果 一 致 允许 登录 ， 反 之 提示 错误 信息 。 

要 用 数据 库存 储 用 户 注册 信息 就 要 分 析 用 户 注册 的 信息 项 ， 并 设 定 相对 应 的 数据 字段 
来 进行 存储 。 

2， 实 施 步 又 


(1) 功能 分 析 。 

用 户 注册 与 登录 功能 主要 通过 四 个 部 分 来 实现 : 用 户 注册 、 用 户 登 录 、 用 户 中 心 、 用 
户 退出 。 

用 户 注册 主要 包含 检测 输入 注册 信息 ， 检 验 是 否 符合 要 求 ， 检 验 用 户 名 是 否 已 存在 ， 
写 入 数据 库 注册 成 功 ; 用 户 登 录 主 要 包含 检验 登录 信息 ， 与 数据 库 数据 核对 ， 信 息 正 确 登 
录 成 功 ， 信 息 不 正确 返回 重新 登录 ; 用 户 中 心包 含 判断 登录 状态 读 取 用 户 信 息 ; 用 户 退 出 
包含 无 条 件 注销 session。 

(2) 数据 库 表 的 设计 。 

建立 数据 库 表 user， 用 来 存储 用 户 的 注册 信息 ， 其 字段 设置 和 字段 数据 类 型 如 表 5.2 
所 示 。 


表 5.2 user 表 字 段 设置 情况 


字 段 名 类 型 描 ” 述 
uid mediumint(8) 主键 ， 自 动 增长 
username char(15) 用 户 名 
password 用 户 密码 
email 用 户 E-mail 
regdate 用 户 注 册 时 间 惟 


建立 数据 库 表 语 句 参 考 如 下 : 


CREATE TABLE "user ( 
mid mediumint(8) unsigned NOT NULL auto_increment, 
"username' char(15) NOT NULL default ", 
‘password' char(32) NOT NULL default ", 
‘email' varchar(40) NOT NULL default ", N\ YL1/ 
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Tegdate' int(10) unsigned NOT NULL default '0', 
PRIMARY KEY (‘uid') 
)ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO INCREMENT=]:; 


(3) 代码 设计 。 

各 页 面 的 布局 : reg.html， 用 户 注册 信息 填写 页 面 ; conn.php: 数据 库 连 接 包含 文件 ; 
reg.php: 用 户 注 册 处 理 程序 ，login.html: 用 户 登 录 页 面 ，login.php: 用 户 登录 处 理 程序 ; 
my.php: 用 户 中 心 reg.html 页 面 主要 用 于 用 户 填写 注册 信息 。 关 键 代码 如 下 : 


/*CSS 样式 */ 

<style type="text/css"> 
html {font-size:12px:} 
fieldset {width:520px; margin: 0 auto;} 
legend {font-weight:bold; font-size:14px:} 
label {float:left; width:70px: margin-left: 10px:;} 
.left{margin-left:80px;} 
.input {width:150px;} 
span{color: #666666;} 

</style> 

/#javaScript 检测 代码 */ 

<script language=JavaScript> 

<I-- 


function InputCheck(RegForm) 
{ 


if (RegForm.username.value =— "") 


alert(" 用 户 名 不 可 为 空 "); 
RegForm.username.focus(); 
return (false); 

} 

if (RegForm.password.value — "") 

{ 
alert(" 必 须 设 定 登录 密码 1"); 
RegForm.password.focus(); 
return (false); 

3 


1f (RegForm.repass.value != RegForm.password.value) 


alert(" 岗 次 密码 不 一 致 1"); 
RegForm .repass.focus(); 
Tetum (false); 

} 

1f (RegForm.email.value — "") 


alert(" 电 子 邮 箱 不 可 为 空 "); 
RegForm.email.focus(); 
Tetum (false); 

NT 
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//--> 
</script> 

人 # 注 册 信 息 所 
<fieldset> 


<legend> 用 户 注册 </legend> 

<form name="RegForm" method="post" action="reg.php" onSubmit="return InputCheck(this)"> 
<p> 

<label for="usemame" class="label"> 用 户 名 :</label> 

<input id="usermame" name="username" type="text" class="input" /> 
<span>( 必 填 ，3-15 字符 长 度 ， 支 持 汉 字 、 字 母 、 数 字 及 _)</span> 
<p/> 

<p> 

<label for="password" class="label"> 密 码 :</label> 

<input id="password" name="password" type="password" class="input" /> 
<span>( 必 填 ， 不 得 少 于 6 位 )</span> 

<p/> 

<p> 

<label for="repass" class="label"> 重 复 密码 :</label> 

<input id="repass" name="repass" type="password" class="input" /> 

<p/> 

<p> 

<label for="email" class="label"> 电 子 邮 箱 :</label> 

<input id="email" name="email" type="text" class="input" /> 
<span>( 必 填 )</span> 

<p/> 

<p> 

<input type="submit" name="submit" value=" 提交 注册 "class="left" /> 
</p> 

</form> 

</fieldset> 


注册 页 面 效 果 如 图 5.10 所 示 。 


(ex j= 站 localhost/r Witr xX | a lip. 
合 收藏 天 。 | 臣 Wer Docwment 


用 户 注册 
用 户 各 


,支持 汉字 、 字 母 、 数 字 及 


密码 


重复 密码 


电子 邮箱 ， 必 填 ) 


图 5.10 注册 页 面 效 果 


/ 
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conn.php 数据 库 链 接 文 件 代码 如 下 。 


<2php 
$conn = @mysql_connect("localhost","root","root123"); 
if(!$conn){ 

die(" 连 接 数据 库 失败 : " . mysql_errorO): 


mysql_select_db("test", $conn); 

// 字 符 转换 ， 读 库 

mysql_query("set character set 'gbk""): 
/ 写 库 

mysql_query("set names 'gbk""); 

和 


reg.php 用 户 处 理 程序 代码 如 下 。 


<2php 
iisset($_POST[submit])){ 
exit(' 非 法 访问 !"); 
} 
$username = $_POST['username']; 
$password = $_POST['password']: 
S$email =$_POST['email]: 
/注册 信息 判断 
if(!preg_match(/^[\w\x80-\xff]{3,15}$/", $usermame)){ 
exit(' 错 误 : 用 户 名 不 符合 规定 。<a hre 伍 "javascript:history.back(-1):"> 返 回 </a>"); 
: 
这 strlen($password) < 6){ 
exit( 错 误 : 密码 长 度 不 符合 规定 。<a hre 伍 "javascript:history.back(-1);"> 返 回 </a>"); 
} 
if(!preg_match(/^Ww+([-+.]w+)*@w+([-.]wt)*.w+([-.]w+)*$/", Semail)){ 
exit(' 错 误 : 电子 邮箱 格式 错误 。<a hre 仁 "javascript:history.back(-1):"> 返 回 </a>"); 


} 

/包含 数据 库 连 接 文件 

include(conn.php); 

/检测 用 户 名 是 否 已 经 存在 

$check_query = mysql_query("select uid from user where usemame='$username’ limit 1"); 

if(mysql_fetch array($check query)){ 
echo ' 错 误 : 用 户 名 ',$usemame,' 已 存在 。<a hre 伍 "javascript:history.back(-1):"> 返 回 </a>'; 
exit: 


} 

// 写 入 数据 

$password = MD5($password); 
$regdate = time(); 


$sql = "INSERT INTO user(usemame.password.email,regdate)VALUES('$usemame','$password','$email', 


Sregdate)"; 
if(mysql_query($sql,$conn)){ 

exit( 用 户 注 册 成 功 ! 点 击 此 处 <a hre 全 "login.html"> 登 录 </a>"); 
}else{ 

echo ' 抱 歉 ! 添加 数据 失败 : ',mysql_error0,'<br />'; 


echo "点 击 此 处 <a hre 伍 "javascript:history.back(-1):"> 返 回 </a> 


?> 


login.html 用 户 登 录 页 面 代 码 如 下 。 


<!DOCTYPE html PUBLIC "-WW3CWDTD XHTML 1.0 Transitional//EN" 
"http://www.w3.o0rg/TR/xhtmll/DTD/xhtmll -transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gbk" /> 
<title> 用 户 登录 </title> 
<style type="text/css"> 
html {font-size:12px;} 
fieldset {width:300px; margin: 0 auto;} 
legend {font-weight:bold; font-size:14px:} 
.label {float:left; width:70px; margin-left:10px;} 
.left{margin-left:80px:} 
.input {width:150px;} 
span{color: #666666;} 
</style> 
<script language=JavaScript> 
<!-- 


function InputCheck(LoginForm) 
{ 
if (LoginForm.usermame.value =— "") 
t 
alert(" 请 输入 用 户 名 !"); 
LoginForm.username.focus(); 
return (false); 
} 
if (LoginForm.password.value =— "") 
{ 
alert(" 请 输入 密码 1"); 
LoginForm.password.focus(); 
return (false); 
} 
} 


//--> 

</script> 

</head> 

<body> 

<div> 

<fieldset> 

<legend> 用 户 登 录 </legend> 
<form name="LoginForm" method="post" action="login.php" onSubmit="return InputCheck(this)"> 
<p> 

<label for="usemame" class="label"> 用 户 名 :</label> 
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<input 1d="usermame" name="username" type="text" class="input" /> 
<p/> 

<p> 

<label for="password" class="label"> 密 码 :</label> 


<input 1d="password" name="password" type="password" class="input" /> 


<p/> 
<p> 
<input type="submit" name="submit" value=” 确 定 "class="left" /> 
</p> 
</form> 
</fieldset> 
</div> 
</body> 
</html> 
登录 页 面 效 果 如 图 5.11 所 示 。 
从 用 户 登录 一 Windows Internet Explore， 
(IS -le leeahes ltr | x | | jl 
会 收藏 严 。 臣 用 户 合 录 
用 户 本 录 
用 户 各 
密码 
确定 


图 5.11 登录 页 面 效 果 
login.php 登录 处 理 程序 代码 如 下 : 


<2php 
session start(); 


// 注 销 登录 
if($_GET['action'] =— "logout"){ 
Unset($_SESSION['userid']): 
unset($_ SESSION[usermame']): 
echo ' 注 销 登 录 成 功 ! 点 击 此 处 <a hre 人 "login.html"> 登 录 </a>'; 
exit: 


} 


/登录 
这 lisset($_POST[submit])){ 
exit(' 非 法 访问 !"); 
} 
$username = htmlspecialchars($_POST['usermame']); 
S$password = MD5($_POST['password']); 


a // 包 含 数据 库 连 接 文件 
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include(conn.php); 
/检测 用 户 名 及 密码 是 否 正确 
$check query = mysql query("select uid from user where username='$username' and password= 
'$password' 
limit 1"): 
if($result = mysql_ fetch array($check query)){ 
// 登 录 成 功 
$_SESSION['username'] = $username; 
$_SESSION['userid'] = $result['uid"]; 
echo $username," 欢迎 你 ! 进入 <a hre 全 "myphp"> 用 户 中心 </a><br />'; 
echo ' 点 击 此 处 <a hre 全 "login.php?action=logout"> 注 销 </a> 登录 ! <br />'; 
exit; 
}else { 
exit( 登 录 失 败 ! 点 击 此 处 <a href="javascript:history.back(-1);"> 返 回 </a> 重 试 "); 
} 
?> 
my.php 用 户 中 心 程序 代码 : 
<2php 
session_start(); 


// 检 测 是 否 登录 ， 若 没 登 录 则 转向 登录 界面 
ifRlisset($_SESSION[userid])){ 
header("Location:login.html"); 
exit(); 


} 


// 包 含 数据 库 连 接 文件 

include(conn.php); 

$userid =$_SESSION[userid']: 

$username = $_SESSION[usemame']: 

$user_query = mysql_query("select * from user where uid=$userid limit 1"); 
$row = mysql fetch_array($user_query); 

echo ' 用 户 信息 : <br />>'; 

echo ' 用 户 ID: ',$userid,'<br />'; 

echo ' 用 户 名 : ',$username,'<br />'; 

echo ' 邮 箱 : ,$row['email],<br />'; 

echo ' 注 册 日 期 : ',date("Y-m-d", Srow[regdate]),<br />'; 

echo '<a href="login.php?action=logout"> 注 销 </a> 登录 <br />'; 
?> 


练习 

1. PHP 连接 MySQL 前 需要 做 哪些 准备 工作 ? 
2. 常用 的 PHP 操作 MySQL 的 函数 有 哪些 ? 
3. 在 PHP 中 如 何 对 多 条 记录 进行 分 页 ? 
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IOULs 


> 类 与 对 象 
> 构造 函数 与 析 构 函数 
> 类 的 基本 应 用 


识 点 、 技 能 点 


六 了 解 类 与 对 象 

> 掌握 抽象 类 与 实例 化 对 象 的 方法 
> 掌握 构造 函数 与 析 构 函数 

> 了 解 类 与 对 象 的 基本 应 用 与 特点 
> 掌握 类 与 对 象 的 应 用 方法 


教学 基础 要 求 


> 掌握 抽象 类 与 实例 化 对 象 的 方法 
> 掌握 构造 函数 与 析 构 函数 
> 掌握 类 与 对 象 的 应 用 方法 


任务 ] 类 与 对 象 


任务 描述 

回 ”正确 认识 面向 对 象 的 概念 以 及 面向 对 象 编程 
回 ”认识 类 与 对 象 

回 ”理解 类 与 对 象 之 间 的 关系 

回 ”学 习 如 何 抽象 类 与 实例 化 对 象 

回 ”学 习 访问 控制 

知识 汇总 


6.1.1 PHP 面向 对 象 概 述 


面向 对 象 编程 (Object Oriented Programming，OOP) ， 又 称 面 向 对 象 程序 设计 ， 是 一 
种 计算 机 编程 架构 , OOP 的 一 条 基本 原则 是 计算 机 程序 是 由 单个 能 够 起 到 子 程序 作用 的 单 
元 或 对 象 组 合 而 成 的 ，OOP 达到 了 软件 工程 的 3 个 目标 : 重用 性 、 灵 活性 和 扩展 性 。 为 了 
实现 整体 运算 ， 每 个 对 象 都 能 够 接收 信息 、 处 理 数 据 和 向 其 他 对 象 发 送信 息 。 面 向 对 象 一 
直 是 软件 开发 领域 比较 热门 的 话题 。 首 先 ， 面向 对 象 符合 人 类 看 待 事物 的 一 般 规律 。 其 次 ， 
采用 面向 对 象 方法 可 以 使 系统 各 部 分 各 司 其 职 、 各 尽 所 能 ， 为 编程 人 员 敞 开 了 一 扇 大 门 ， 
使 其 编程 的 代码 更 简洁 、 ee 有 人 说 PHP 不 是 一 个 真 
正 的 面向 对 象 的 语言 ， 这 是 事实 。PHP 是 一 个 混合 型 语言 ， 用 户 可 以 使 用 OOP， 也 可 以 使 
用 传统 的 过 程 化 编程 。 然 而 ， ae 用 户 可 能 需要 在 PHP 中 只 使 用 OOP 去 声明 
类 ， 而 且 项 目 里 只 用 对 象 和 类 。 

PHP 支持 面向 对 象 的 编程 方法 。 尤 其 是 到 了 PHP 5， 面 向 对 象 的 特性 被 大 大 加 强 ， 虽 
然 目 前 PHP 作为 一 门 Web 开发 语言 ,其 对 面向 对 象 特性 的 支持 程度 与 纯粹 的 面向 对 象 语言 
(如 Java 等 ) 还 有 很 大 差距 , 但 在 一 定 程度 上 已 经 给 PHP 开发 者 带 来 很 大 便利 。 因 此 掌握 
PHP 面向 对 象 编程 就 显得 十 分 必要 

那么 到 底 什么 才 是 面向 对 象 编程 呢 ? 这 里 举 一 个 简单 的 例子 来 帮助 读者 理解 。 如 果 想 
建立 一 个 电脑 教室 ， 首 先 要 有 一 个 房间 ， 房 间 里 面 要 有 N 台电 脑 、N 张 桌子 、N 把 椅子 、 
白板 和 投影 机 等 ， 这 些 就 是 对 象 ， 是 能 看 到 的 一 个 个 的 实体 ， 可 以 说 电脑 教室 的 单位 就 是 
一 个 个 的 实体 对 象 ， 它 们 共同 组 成 了 这 个 电脑 教室 。 而 我 们 是 做 程序 ， 这 和 面向 对 象 有 什 
么 关系 呢 ? 开发 一 个 系统 程序 和 建 一 个 电脑 教室 类 似 , 要 把 每 个 独立 的 功能 模块 抽象 成 类 ， 
形成 对 象 ， 由 多 个 对 象 组 成 系统 ， 这 些 对 象 之 间 都 能 够 进行 接收 信息 、 处 理 数 据 和 向 其 他 
对 象 发 送信 息 等 相互 作用 ， 就 构成 了 面向 对 象 的 程序 。 

关于 面向 对 象 的 编程 方法 ， 是 一 门 专门 的 学 问 ， 有 很 多 著作 来 阐述 这 个 问题 。 关 于 类 、 
对 象 、 方 法 、 成 员 、 继 承 、 封 装 、 重 载 、 构 造 器 等 名 词 ， 对 于 一 个 没有 接触 过 面向 对 象 编 
程 的 读者 来 说 可 能 一 头 雾 水。 由 于 阐述 面向 对 象 的 原理 不 是 本 书 的 主要 内 容 ， 因 此 本 书 不 AN 
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会 深入 探讨 这 些 内 容 ， 但 是 会 在 遇 到 每 个 名 词 时 进行 尽量 简短 、 通 俗 的 解释 。 如 果 读 者 在 
此 之 前 就 具备 了 面向 对 象 编程 的 经 验 ， 那 么 学 习 本 章 将 会 非常 轻松 。PHP 的 面向 对 象 要 比 
专门 的 面向 对 象 编程 语言 简单 得 多 。 如 果 读 者 没有 任何 面向 对 象 编程 知识 ， 也 能 够 通过 我 
们 的 介绍 慢 慢 领会 。 不 过 还 是 建议 这 类 读者 先 参阅 一 些 专门 介绍 面向 对 象 编程 的 书籍 ， 这 
样 再 学 习 起 来 会 更 加 顺畅 。 

必须 清楚 地 说 明 一 点 , PHP 支持 面向 对 象 的 编程 , 但 并 不 是 只 能 以 面向 对 象 方式 编程 ， 
换 句 话说， 不 了 解 PHP 的 面向 对 象 编程 并 不 影响 PHP 的 学 习 。 即 使 跳 过 本 项 目 ， 也 基本 
不 会 影响 后 面 内 容 的 学 习 。 事 实 上 ， 由 于 Web 程序 规模 有 限 ， 每 个 网 页 程序 一 般 是 儿 十 到 
几 百 行 ， 数 千 甚 至 数 万 行 的 程序 并 不 多 见 。 再 加 上 Web 程序 基本 上 是 独立 的 个 体 ， 它 们 运 
行 时 互 不 相干 ， 这 就 使 得 单个 网 页 程序 的 内 部 逻辑 比较 简单 ， 并 不 是 十 分 复杂 ， 因 此 面向 
对 象 的 编程 思路 并 不 会 发 挥 太 大 作用 。 于 是 实际 开发 中 大 多 数 PHP 开发 者 还 是 主要 采用 传 
统 的 面向 过 程 的 方法 。 因此， 即使 读者 对 面向 对 象 的 编程 没有 经 验 ,学 习 本 项 目 感到 困难 ， 
也 不 必 表 失 信心 。 面 向 对 象 到 目前 为 止 还 没有 成 为 PHP 的 核心 。 


6.1.2 ”类 与 对 象 的 定义 和 应 用 


从 程序 的 角度 出 发 ， 本 节 把 类 放 在 最 前 面 介绍 。 因 为 只 有 定义 了 类 ， 才 能 创建 这 个 类 
的 实例 (对 象 )。 但 是 实际 上 如 果 按 照 类 的 产生 来 看 ， 类 是 从 现实 世界 的 事物 (对象) 中 抽 
象 而 来 的 ， 是 客观 世界 在 计算 机 中 的 逻辑 表示 ， 因 此 是 先 有 对 象 后 有 类 。 

面向 对 象 的 一 个 重要 理念 就 是 万 事 万 物 皆 对 象 。 客 观 世 界 中 的 任何 事物 ， 一 个 人 、 一 
辆 车 、 一 种 物体 ， 都 可 以 视 为 一 个 对 象 。 对 象 还 可 以 是 抽象 的 概念 ， 如 天 气 变化 、 鼠 标 事 
件 等 。 联 系 客观 世界 的 事物 ， 可 以 很 容易 归纳 出 对 象 的 两 个 特征 : 状态 和 行为 。 每 个 对 象 
都 有 自身 的 状态 (或 称 属性 )， 也 有 自己 的 行为 (操作 )。 例 如 一 个 人 有 身高 、 体 重 、 性 别 
等 自然 属性 ， 也 有 姓名 、 职 业 等 逻辑 属性 。 人 还 有 自己 的 行为 ， 如 走 、 立 、 坐 、 跑 等 。 一 
辆 车 有 颜色 、 型 号 、 价 格 、 时 速 等 属性 ， 也 有 起 步 、 换 档 、 刹 车 、 转 弯 等 行为 。 

具体 来 说 ， 类 是 具有 相同 属性 和 服务 的 一 组 对 象 的 集合 。 它 为 属于 该 类 的 所 有 对 象 提 
供 统一 的 抽象 描述 ， 其 内 部 包括 属性 和 服务 两 个 主要 部 分 。 在 面向 对 象 的 编程 语言 中 ， 类 
是 一 个 独立 的 程序 单位 ， 它 应 该 有 一 个 类 名 并 包括 属性 说 明和 服务 说 明 两 个 主要 部 分 。 

而 对 象 是 系统 中 用 来 描述 客观 事物 的 一 个 实体 ， 它 是 构成 系统 的 一 个 基本 单位 。 一 个 
对 象 由 一 组 属性 和 对 这 组 属性 进行 操作 的 一 组 服务 组 成 。 从 更 抽象 的 角度 来 说 ， 对 象 是 问 
题 域 或 实现 域 中 某 些 事物 的 一 个 抽象 ， 它 反映 该 事物 在 系统 中 需要 保存 的 信息 和 发 挥 的 作 
用 ; 它 是 一 组 属性 和 有 权 对 这 些 属性 进行 操作 的 一 组 服务 的 封装 体 。 客 观 世 界 是 由 对 象 和 
对 象 之 间 的 联系 组 成 的 。 
类 与 对 象 的 关系 就 如 模具 和 铸件 的 关系 ， 类 的 实例 化 结果 就 是 对 象 ， 而 对 一 类 对 象 的 
抽象 就 是 类 。 类 描述 了 一 组 有 相同 特性 〈 属 性 ) 和 相同 行为 〈 方 法 ) 的 对 象 。 

1.， 抽象 类 

既然 一 个 类 是 由 一 类 事物 或 者 逻辑 抽象 而 来 的 ， 其 中 必然 包含 这 类 事物 或 逻辑 的 基本 
\ / 要 素 和 区 别 于 其 他 类 的 特性 。 一 个 内 容 为 空 的 类 虽然 是 合法 的 ， 但 是 毫 无 意义 。 一 个 类 除 
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了 一 个 名 称 的 声明 一 一 类 声明 之 外 ， 其 内 容 由 两 部 分 组 成 : 变量 和 方法 。 类 的 变量 和 方法 
统称 为 类 的 成 员 。 

前 面 已 经 介绍 过 ,面向 对 象 程序 的 单位 就 是 对 象 ， 但 对 象 又 是 通过 类 的 实例 化 而 来 的 ， 
所 以 首先 要 考虑 的 是 如 何 来 声明 类 。 做 出 一 个 类 很 容易 ， 只 要 掌握 基本 的 程序 语法 、 定 义 
规则 即 可 ,那么 难点 在 哪里 呢 ? 一 个 项 目 要 用 到 多 少 个 类 、 用 多 少 个 对 象 、 在 哪里 定义 类 、 
定义 一 个 什么 样 的 类 、 这 个 类 实例 化 出 多 少 个 对 象 、 类 里 面 有 多 少 个 属性 和 方法 等 ， 这 就 
需要 读者 在 实际 的 开发 中 就 实际 问题 分 析 设 计 和 总 结 了 。 

类 的 定义 如 下 : 

class 类 名 { 

} 


使 用 一 个 关键 字 class ， 后 面 加 一 个 想 要 的 类 名 以 及 一 对 花 括 号 ， 这 样 一 个 类 的 结构 
就 定义 出 来 了 ， 只 要 在 里 面 写 入 代码 即 可 。 但 是 里 面 写 什 么 ? 能 写 什么 ? 怎样 写 才 是 一 个 
完整 的 类 呢 ? 上 面 讲 过 ， 使 用 类 是 为 了 让 它 实 例 出 对 象 来 给 我 们 用 ， 这 就 要 知道 你 想 要 的 
是 什么 样 的 对 象 。 比 如 说 ， 一 个 人 就 是 一 个 对 象 ， 要 想 把 一 个 你 看 好 的 人 推荐 给 领导 ， 首 
先 ， 你 会 介绍 这 个 人 的 姓名 、 人 性别、 年龄、 身高、 体重、 电话、 家庭 住址 等 。 然 后 ， 你 要 
介绍 这 个 人 能 做 什么 ， 可 以 开车 ， 会 说 英语 ， 可 以 使 用 电脑 等 。 只 要 你 多 介绍 一 点 ， 别 人 
就 对 这 个 人 多 一 点 了 解 ， 这 就 是 我 们 对 一 个 人 的 描述 。 

现在 总 结 一 下 ， 所 有 的 对 象 用 类 去 描述 都 是 类 似 的 ， 从 上 面 对 人 的 描述 可 以 看 到 ， 做 
出 一 个 类 来 ， 从 定义 的 角度 分 两 部 分 :从 静态 上 描述 和 从 动态 上 描述 。 静 态 上 的 描述 就 是 
我 们 所 说 的 属性 ， 如 人 入 的 姓名 、 性 别 、 年 龄 、 身 高 、 体 重 、 电 话 、 家 庭 住 址 等 。 动 态 上 的 
描述 也 就 是 对 象 的 功能 ， 如 这 个 人 可 以 开车 ， 会 说 英语 ， 可 以 使 用 电脑 等 。 抽 象 成 程序 时 ， 
我 们 把 动态 的 描述 写成 函数 或 者 说 是 方法 (函数 和 方法 是 一 样 的 ) 。 所 以 ， 所 有 类 都 是 从 
属性 和 方法 这 两 方面 去 写 ， 属 性 又 叫做 这 个 类 的 成 员 属 性 ， 方 法 叫做 这 个 类 的 成 员 方 法 。 
例如 : 

class 人 { 

成 员 属性 : 姓名 、 人 性别、 年 龄 、 身 高 、 体 重 、 电 话 、 家 庭 住址 

成 员 方法 : 可 以 开车 ， 会 说 英语 ， 可 以 使 用 电脑 

上 

回 ”属性 : 通过 在 类 定义 中 使 用 关键 字 var 来 声明 变量 ， 即 创建 了 类 的 属性 ， 虽 然 在 

声明 成 员 属 性 时 可 以 给 定 初 始 值 ， 但 是 在 声明 类 时 给 成 员 属 性 初始 值 是 没有 必要 
的 。 比 如 ， 要 是 把 人 的 姓名 赋 上 “ 张 三 ”， 屠 么 用 这 个 类 实例 出 几 十 个 人 ， 这 几 
十 个 人 都 叫 张 三 ， 所 以 没有 必要 。 在 实例 出 对 象 后 给 成 员 属 性 初始 值 即 可 ， 如 var 


$somevar: 。 
回 方法 成员 函数 ) : 通过 在 类 定义 中 声明 函数 ， 即 创建 了 类 的 方法 。 
function somefun( 参 数列 表 ) 
Es } 


NI/ 
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完整 的 代码 如 例 6.1 所 示 。 


【 例 6.1】 


<2php 
class Person 


{ 

/下 面 是 人 的 成 员 属 性 
Var $name; 

Var $sex; 

Var $age; 
/下 面 是 人 的 成 员 方法 
function sayO) 

echo "这 个 人 在 说 话 "; 
} 

function run() 


和 
echo "这 个 人 在 走路 "; 
) 
上 


?> 


/人 的 姓名 
/人 的 性 别 
// 人 的 年 龄 


// 这 个 人 可 以 说 话 的 方法 


// 这 个 人 可 以 走路 的 方法 


上 面 就 是 一 个 类 的 声明 ， 从 属性 和 方法 上 声明 出 来 一 个 类 。 需 要 注意 ， 在 声明 时 最 好 


class 矩形 

{ 
/矩形 的 属性 
和 矩形 的 长 ; 

和 矩形 的 宽 ; 
/矩形 的 方法 
和 矩形 的 周 长 ; 
和 矩形 的 面积 ; 
本 


【 例 6.2】 
<2php 


class Rect 

Var $kuan: 

Var $gao; 

function zhouChang() 


下 面 再 做 一 个 矩形 类 。 


不 要 给 成 员 属 性 初始 的 值 ， 因 为 声明 的 类 是 一 个 描述 信息 ， 将 来 用 它 实 例 化 对 象 ， 比 如 实 
例 化 出 来 10 个 人 对 象 ， 那 么 这 10 个 人 ， 每 一 个 人 的 姓名 、 性 别 、 年 龄 都 是 不 一 样 的 ， 所 
以 最 好 是 对 每 个 对 象 分 别 赋值 。 

用 同样 的 办 法 可 以 做 出 想 要 的 所 有 类 ， 
义 成 类 ， 然 后 去 实例 化 对 象 。 
为 了 加 强 对 类 的 理解 ， 


只 要 能 用 属性 和 方法 描述 出 来 的 实体 都 可 以 定 


{ 

计算 矩形 的 周 长 ; 
} 

function mianJiO 


‘ 
计算 矩形 的 面积 ; 
} 
} 


?> 

如 果 用 这 个 类 来 创建 出 多 个 矩形 对 象 ， 每 个 矩形 对 象 都 有 自己 的 长 和 宽 ， 就 可 以 求 出 
各 和 矩形 的 周 长 和 面积 了 。 

2.， 实例 化 对 象 

“实例 化 ”是 一 个 术语 ， 可 以 将 其 理解 为 “具体 化 ”。 通 过 上 面 的 学 习 知 道 ， 类 是 抽象 
出 来 的 一 个 罗 辑 单位 ， 虽 然 用 具体 的 代码 书写 出 来 了 ， 这 个 类 仍然 只 是 某 类 事物 的 定义 ， 
而 不 是 事物 本 身 。 要 在 程序 中 使 用 这 类 事物 ， 首 先 要 创建 出 这 类 事物 的 一 个 实体 ， 这 就 是 
类 的 实例 化 。 在 面向 对 象 的 程序 设计 中 将 创建 的 实体 称 为 对 象 。 
当 定 义 好 类 后 ， 可 以 使 用 new 关键 字 来 生成 一 个 对 象 。 
$ 对 象 名 称 = new 类 名 称 0; 


【 例 6.3】 
<2php 
class Person 
{ 
/下 面 是 人 的 成 员 属性 
Var $name; /人 的 姓名 
Var $sex; /人 的 性 别 
var $age; /人 的 年 龄 
/下 面 是 人 的 成 员 方法 
function say() // 这 个 人 可 以 说 话 的 方法 
{ 
echo "这 个 人 在 说 话 "; 
} 
function run0) // 这 个 人 可 以 走路 的 方法 
{ 
echo "这 个 人 在 走路 "; 
} 
} 


$pl=new Person(); 
$p2=new Person(); 
$p3=new Person(); 
?> 

$p1=new Person(); 


上 述 代码 就 是 通过 类 产生 实例 对 象 的 过 程 ，$p1、S$p2 和 $p3 是 实例 出 来 的 对 象 名 称 ， 
可 见 ， 一 个 类 可 以 实例 出 多 个 对 象 ， 每 个 对 象 都 是 独立 的 ， 上 面 的 代码 相当 于 实例 出 3 个 、 (7_ 
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人 ， 人 与 人 之 间 是 没有 联系 的 ， 只 能 说 明 他 们 都 是 人 类 ， 每 个 人 朝 
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bh 有 自己 的 姓名 、 性 别 和 


年 龄 的 属性 ， 都 有 说 话 和 走路 的 方法 ， 只 要 是 类 里 面体 现 出 来 的 成 员 属性 和 成 员 方法 ， 实 


例 化 出 来 的 对 象 里 面 就 包含 这 些 属 性 和 方法 。 


对 像 在 PHP 里 面 和 整 型 、 浮 点 型 一 样 ， 也 是 一 种 数据 类 ， 都 上 


于 存储 不 同类 型 数据 ， 


在 运行 时 都 要 加 载 到 内 存 中 ， 那 么 对 象 在 内 存 里 面 是 怎么 体现 的 呢 ? 内 存 从 逻辑 上 大 体 分 
为 4 段 : 栈 空间 段 、 堆 空间 段 、 代 码 段 和 初始 化 静态 段 ， 程 序 里 面 不 同 的 声明 放 在 不 同 的 
内 存 段 里 面 ， 栈 空间 段 是 存储 占用 相同 空间 长 度 并 且 占 用 空间 小 的 数据 类 型 的 地 方 ， 如 整 
型 1、10、100、1000、10000、100000 等 ， 在 内 存 里 面 占用 空间 是 等 长 的 ， 都 是 64 位 4 个 
字 节 。 而 数据 长 度 不 定 长 ， 而 且 占 用 空间 很 大 的 数据 放 在 堆 内 存 里 面 。 栈 内 存 是 可 以 直接 
存 取 的 ， 而 堆 内 存 是 不 可 以 直接 存 取 的 。 上 述 代码 的 对 象 就 是 一 种 大 的 而 且 占用 空间 不 定 


长 的 类 型 ， 所 以 说 对 象 放 在 堆 里 面 ， 但 对 象 名 称 是 放 在 栈 里 面 的 
以 使 用 对 象 。 


这 样 通过 对 象 名 称 就 可 


对 于 代码 $p1=new Person0:，$p1l 是 对 象 名 称 ， 在 栈 内 存 里 面 ，new Person0 是 真正 的 


对 象 ， 在 堆 内 存 里 面 ， 具 体 如 图 6.1 所 示 。 


Spl=pew Person() ; 
栈 内 存 3p2-oew Person 0 : 


$p3=new Person() ; 


图 6.1 实例 化 对 象 图 示 
从 图 6.1 可 以 看 出 ，Spl=new Person(); 等 号 右边 是 真正 的 对 象 实例 ， 是 在 堆 内 存 里 面 的 


实体 ， 图 中 共有 3 次 new Person0， 所 以 会 在 堆 里 面 开辟 3 个 空间 ， 


产生 3 个 实例 对 象 ， 对 


象 之 间 都 是 相互 独立 的 ， 使 用 自己 的 空间 。 在 PHP 中 ， 只 要 有 一 个 new 关键 字 出 现 ， 就 会 


实例 化 出 来 一 个 对 象 ， 在 堆 里 面 开辟 一 块 自己 的 空间 。 


堆 里 面 的 实例 对 象 是 用 于 存储 属性 的 。 例 如 ， 现 在 堆 里 面 的 实例 对 象 中 都 存 有 姓名 、 


性 别 和 年 龄 ， 每 个 属性 又 都 有 一 个 地 址 。 
$pl=new Person(); 等 号 左边 是 一 个 引用 变量 ， 通 过 赋值 运算 符 


“=” 把 对 象 的 首 地 址 赋 


给 $pl 这 个 引用 变量 ， 所 以 Spl 是 存储 对 象 首 地 址 的 变量 ， 存 放 在 栈 内 存 中 。S$pl 相当 于 一 
个 指针 指向 堆 里 面 的 对 象 ， 所 以 可 以 通过 $p1l 来 操作 对 象 ， 通 常 也 称 对 象 引 用 为 对 象 。 


3. 使 用 对 象 中 的 成 员 


PHP 对 象 中 的 成 员 有 两 种 ， 一 种 是 成 员 属性 : 一 种 是 成 员 方法 。 前 面 讲解 了 对 象 的 声 


明 ， 怎 么 去 使 用 对 象 的 成 员 呢 ? 要 想 访问 对 象 中 的 成 员 ， 就 要 使 用 


一 个 特殊 的 操作 符 “->” 


来 完成 : 
回 ” 对象-> 属 性 ， 如 $p1->name: $p2->age: Sp3->sex: 
回 ”对 象 -> 方法 ， 如 $p1->say0; $p2->run(; 


如 下 面 的 实例 。 
【 例 6.4】 
<?php 
class Person 
{ 
/下 面 是 人 的 成 员 属性 
Var $name; /人 的 姓名 
Var $sex; /人 的 性 别 
Var $age; // 人 的 年 龄 
/下 面 是 人 的 成 员 方法 
function sayO // 这 个 人 可 以 说 话 的 方法 
{ 
echo "这 个 人 在 说 话 "; 
} 
function ruanO) // 这 个 人 可 以 走路 的 方法 
{ 
echo "这 个 人 在 走路 "; 
>} 
} 
$pl=new Person(); // 创 建 实例 对 象 $p1 
$p2=new Person(); // 创 建 实例 对 象 $p2 
$p3=new Person(); // 创 建 实例 对 象 $p3 


/下 面 3 行 是 给 $p1 对 象 属性 赋值 
$p1->name=" 张 三 "; 

$p1->sex=" 男 "; 

$p1->age= 
/下 面 3 行 是 访问 $pl 对 象 的 属性 

echo "pl 对 象 的 姓名 是 : ".$p1->name. "<br>"; 

echo "pl 对 象 的 性 别 是 : ".$p1->sex. "<br>"; 

echo "pl 对 象 的 年 龄 是 : ".$p1->age. "<br>"; 

/下 面 两 行 访问 $p1 对 象 中 的 方法 

$pl1->say(); 

$p1->run(); 

/下 面 3 行 是 给 $p2 对 象 属性 赋值 

$p2->name=" 李 四 "; 

$p2->sex=" 女 "; 

$p2->age=30; 

/下 面 3 行 是 访问 $p2 对 象 的 属性 

echo "p2 对 象 的 姓名 是 : ".$p2->name. "<br>"; 

echo "p2 对 象 的 性 别 是 : ".$p2->sex. "<br>"; 

echo "p2 对 象 的 年 龄 是 : ".$p2->age. "<br>"; 

/下 面 两 行 访问 $p2 对 象 中 的 方法 

$p2->say(); 

$p2->run(); a 
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/下 面 3 行 是 给 $p3 对 象 属性 赋值 
$p3->name=" 王 五 ": 

$p3->sex=" 男 "; 

$p3->age=40; 

/下 面 3 行 是 访问 $p3 对 象 的 属性 

echo "p3 对 象 的 姓名 是 : ".$p3->name. "<br>"; 
echo "p3 对 象 的 性 别 是 : ".$p3->sex. "<br>"; 
echo "p3 对 象 的 年 龄 是 : ".$p3->age. "<br>"; 
/下 面 两 行 访问 $p3 对 象 中 的 方法 
$p3->say(; 

$p3->run(); 

?> 


从 例 6.4 中 可 以 看 出 ， 只 要 是 对 象 里 面 的 成 员 ， 就 要 使 用 “对 象 -> 属性 ”、“ 对 象 -> 
方法 ”形式 访问 ， 没 有 其 他 方法 。 

4. Sthis 的 使 用 

“对 象 -> 成 员 ” 是 在 对 象 的 外 部 去 访问 对 象 中 成 员 的 形式 ， 那 么 如 果 想 在 对 象 的 内 部 ， 
让 对 象 里 的 方法 访问 本 对 象 的 属性 ， 或 是 让 对 象 中 的 方法 去 调用 本 对 象 的 其 他 方法 时 该 怎 
么 办 ? 因为 对 象 里 面 的 所 有 成 员 都 要 用 对 象 来 调用 ， 包 括 对 象 的 内 部 成 员 之 间 的 调用 ， 所 
以 在 PHP 中 提供 了 一 个 本 对 象 的 引用 S$this, 每 个 对 象 里 面 都 有 一 个 对 象 的 引用 S$this 来 代表 
这 个 对 象 ， 完 成 对 象 内 部 成 员 的 调用 。this 的 本 意 就 是 “这 个 ”的 意思 ， 上 面 的 实例 中 实 
例 化 3 个 对 象 ， 这 3 个 对 象 里 面 各 自 存在 一 个 Sthis 分 别 代 表 对 象 Spl1、$p2、S$p3。Sthis 的 
使 用 原理 如 图 6.2 所 示 。 

Spl=new Person(); 


Se 0 


图 6.2 S$this 的 使 用 原理 


通过 图 6.2 可 以 看 到 ，$this 就 是 对 象 内 部 代表 该 对 象 的 引用 ， 在 对 象 内 部 调用 本 对 象 
的 成 员 和 在 对 象 外 部 调用 对 象 成 员 所 使 用 的 方式 是 一 样 的 。 
加 ”Sthis-> 属 性 ， 如 S$this->name; $this->age: $this->sex: 
加 ”S$this-> 方 法 ， 如 S$this->say(; Sthis->run0); 
修改 例 6.4， 让 每 个 人 都 说 出 自己 的 姓名 、 人 性别 和 年 龄 ， 如 例 6.5 所 示 。 
【 例 6.5】 


<?php 


Wy class Person 
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/下 面 是 人 的 成 员 属性 


Var $name; /人 的 姓名 

Var $sex; /人 的 性 别 

Var $age; // 人 的 年 龄 
/下 面 是 人 的 成 员 方法 

function say0) /这 个 人 可 以 说 话 的 方法 


{ 

echo "我 的 名 字 叫 : ".$this->name.” 性 别 :".$this->sex." 我 的 年 龄 是 : 
".$this->age."<br>"; 

站 

function run() // 这 个 人 可 以 走路 的 方法 
{ 

echo "这 个 人 在 走路 "; 

} 

} 

S$pl=new Person(); // 创 建 实例 对 象 $p1l 
$p2=new Person(); // 创 建 实例 对 象 $p2 
$p3=new Person(); // 创 建 实例 对 象 $p3 
/下 面 3 行 是 给 $p1l 对 象 属性 赋值 

$p1->name=" 张 三 "; 

$p1->sex=" 男 "; 

$p1->age=20; 

/下 面 访 问 $pl 对 象 中 的 说 话 方法 

$p1->sayO; 

/下 面 3 行 是 给 $p2 对 象 属性 赋值 

$p2->name=" 李 四 "; 

$p2->sex=" 女 "; 

$p2->age=30; 

// 下 面 访 问 $p2 对 象 中 的 说 话 方法 

$p2->sayO; 

/下 面 3 行 是 给 $p3 对 象 属性 赋值 

$p3->name=" 王 五 "; 

$p3->sex=" 男 " 

$p3->age=40; 

// 下 面 访 问 $p3 对 象 中 的 说 话 方法 

$p3->say(); 

?> 


输出 结果 为 : 


我 的 名 字 叫 : 张 三 性 别 : 男 我 的 年 龄 是 : 20 
我 的 名 字 叫 : 李 四 性 别 : 女 我 的 年 龄 是 : 30 
我 的 名 字 叫 : 王 五 性 别 : 男 我 的 年 龄 是 : 40 


分 析 一 下 以 下 方法 : 
function sayO // 这 个 人 可 以 说 话 的 方法 


{ 
echo "我 的 名 字 叫 : ".$this->name."” 性 别 : ".$this->sex." 我 的 年 龄 是 : cE 
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".$this->age."<br>"; 
上 


在 $p1、$p2 和 $p3 这 3 个 对 象 中 都 有 方法 say0，S$this 分 别 代表 这 3 个 对 象 ， 调 用 相应 
的 属性 ， 打 印 出 属性 的 值 ， 这 就 是 在 对 象 内 部 访问 对 象 属性 的 方式 ， 如 果 想 在 say0 方 法 中 
调用 run0 方 法 ， 可 以 使 用 $this->run0) 的 方式 来 完成 调用 。 

5. 访问 控制 

由 上 面 的 几 个 例子 可 以 看 出 ， 同 一 个 类 的 成 员 可 以 在 不 同 的 场合 以 不 同 的 方式 调用 。 
这 看 似 是 一 种 灵活 性 的 表现 ， 但 是 对 于 一 个 健壮 的 、 安 全 的 程序 而 言 ， 这 种 随意 的 访问 方 
式 很 容易 带 来 负面 问题 ， 不 妨 举 一 个 简单 的 例子 。 

【 例 6.6】 


<2php 

class getDate{ 

var $month; 

Var $day; 

function setDate($m,$d){ 
$m = (int)$m; 

$d = (int)$d:; 

if($m<1) $m=1; 

if($d<1) $d=1; 

if($m>12) $m=12; 
if($d>31) $d=31:; 
$this->month = $m:; 
$this->day = $d; 

} 

function showDateO{ 
return $this->month." 月 ".$this->day." 日 <P>"; 
} 

} 

$dayl = new getDate(); 
// 以 正常 参数 调用 方法 
$day1->setDate(5,12); 
echo $dayl->showDate(); 
// 以 异常 参数 调用 方法 
$day1->setDate(14,34); 
echo $dayl1->showDate(); 
// 绕 过 方法 直接 操作 变量 
$day1->month = 14; 
$dayl->day = 34; 

echo $dayl1->showDate(); 
> 


上 面 的 程序 中 定义 了 类 getDate， 类 中 有 2 个 变量 ， 分 别 表示 月 、 日 。 定 义 了 setDate0 
方法 来 设置 变量 值 ， 定 义 了 showDate0 方 法 来 格式 化 返回 变量 值 。 我 们 都 知道 月 份 不 可 能 


二 超过 12， 日 不 可 能 超过 31。 因 此 在 setDate0 方 法 中 对 参数 值 进行 了 验证 ， 如 果 出 现 了 异常 
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的 参数 ， 则 进行 处 理 〈 至 于 如 何 处 理 可 以 根据 程序 需要 自行 编写 )。 最 后 通过 3 种 方式 来 设 
置 变量 值 并 查看 结果 ， 运 行 结果 如 图 6.3 所 示 。 


12 月 31 日 


14 月 34 日 


图 6.3 随意 访问 成 员 带 来 的 混乱 图 示 


通过 运行 结果 可 以 看 出 ， 如 果 不 经 控制 而 随意 存 取 一 个 类 中 的 变量 ， 则 很 容易 导致 数 
据 异 常 ， 即 提供 的 数据 可 能 不 在 合法 的 范围 内 。 程 序 运 行 时 如 果 发 生 这 样 的 情况 ， 将 对 程 
序 的 执行 带 来 难以 预料 的 后 果 。 

如 何 控制 类 的 成 员 的 访问 权限 呢 ? 也 就 是 说 实现 对 某 些 成 员 随意 访问 ， 而 对 某 些 成 员 
限制 访问 ， 这 就 是 PHP 中 的 访问 控制 。 

在 PHP 中 ， 对 属性 或 方法 的 访问 控制 ， 是 通过 在 前 面 添 加 关键 字 public、protected 或 
private 来 实现 的 。 由 public 所 定义 的 类 成 员 可 以 在 任何 地 方 被 访问 ; 由 protected 所 定义 的 
类 成 员 则 可 以 被 其 所 在 类 及 其 子 类 访问 (关于 子 类 的 概念 将 在 本 章 的 后 面 介绍 );， 而 由 
private 定义 的 类 成 员 则 只 能 被 其 所 在 类 访问 。 下 面 再 用 一 个 实例 来 说 明 。 

【 例 6.7】 
<2php 

class MyClass 


public $public = 'Public'; 
protected S$protected = 'Protected'; 
private S$private ='Private'; 
function printHello0 

{ 

echo $this->public; 

echo $this->protected; 

echo $this->private; 


} 

$obj = new MyClass(); 

echo $obj->public:; // 这 行 能 被 正常 执行 

echo $obj->protected; // 这 行 会 户 -个 致命 错误 
echo $obj->private; // 这 行 也 会 产生 一 个 致命 错误 
$obj->printHello0: /可 以 正常 输出 

?> 


程序 的 第 4 一 6 行 定义 了 3 个 变量 , 与 以 前 的 写法 不 同 的 是 , 在 其 前 面 增加 了 访问 控制 
符 。 使 用 不 同 的 访问 控制 符 修饰 的 变量 其 访问 权限 也 不 同 ， 从 第 15 一 17 行 的 执行 结果 可 以 
看 出 这 种 差异 。 第 15 行 通过 对 象 Sobj 访问 变量 Spublic， 由 于 该 变量 的 访问 控制 为 public， 下 人/_ 
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即 任 何 地 方 都 可 以 使 用 ,因此 此 句 执行 成 功 . 第 16 和 17 行 会 报错 ,是 因为 protected 和 private 
两 种 类 型 都 不 允许 通过 对 象 直接 调用 。 但 是 第 19 行 通过 printHello() 方 法 来 输出 Sprotected 
和 Sprivate 两 个 变量 ,就 可 以 成 功 。 这 是 因为 printHello0 方 法 在 类 的 内 部 定义 ,执行 时 相当 
于 在 所 在 类 的 内 部 调用 两 个 变量 ， 这 是 允许 的 。 而 通过 对 象 直接 访问 就 是 错误 的 。 

由 此 可 见 , 在 例 6.6 中 只 需要 将 $month 和 $day 两 个 变量 的 声明 部 分 作 如 下 修改 , 即 可 
防止 通过 外 部 直接 赋值 。 

Private $month; 

private $day; 

这 样 一 来 ， 试 图 直接 通过 $day1->month 来 为 其 赋值 就 会 报错 ， 因 而 只 能 通过 setDate0 
方法 来 赋值 ， 这 样 就 避免 了 数据 不 合法 导致 数据 混乱 的 问题 。 

当然 ， 这 里 所 举 的 是 两 个 非常 简单 的 例子 ， 实 际 应 用 中 的 程序 要 复杂 得 多 ， 要 特别 注 
意 每 个 成 员 的 访问 控制 ， 将 可 能 存在 的 危险 降 到 最 低 。 

学 过 了 访问 控制 之 后 ， 就 可 以 来 澄清 一 个 前 面 提 到 的 问题 了 。 在 前 面 的 内 容 中 ， 定 义 
类 的 变量 时 一 般 使 用 var 作为 关键 字 ， 实 际 上 这 是 PHP 4 中 的 写法 ， 到 了 PHP 5 中 ， 虽 然 
仍然 保持 兼容 ， 但 是 推荐 使 用 public、Pprotected 或 private 来 修饰 变量 。 

public、protected、private 关键 字 同 样 可 以 应 用 于 方法 ， 来 实现 对 方法 的 访问 控制 。 其 
控制 原理 与 变量 相同 ， 因 此 不 再 给 出 具体 例子 ， 请 读者 自行 设计 一 个 程序 来 验证 。 

当 一 个 方法 没有 使 用 访问 控制 修饰 符 修饰 时 ， 默 认为 public。 
练习 
1. 简 述 类 与 对 象 之 间 的 关系 。 
2. 类 的 定义 方法 。 
3. Sthis 的 作用 。 


任务 2 攀 造 西数 与 机 构 耳 数 


任务 描述 

大 多 数 类 都 有 一 种 称 为 构造 函数 的 特殊 方法 。 当 创建 一 个 对 象 时 ， 它 将 自动 调用 构造 
函数 ， 也 就 是 使 用 new 关键 字 来 实例 化 对 象 时 自动 调用 构造 方法 。 构 造 函 数 〈 构 造 器 ) 是 
面向 对 象 编程 中 的 一 种 重要 机 制 ， 本 任务 将 重点 学 习 PHP 中 的 构造 函数 与 析 构 函数 。 


知识 汇总 
6.2.1 构造 函数 

所 谓 构造 函数 ， 是 指 类 中 的 一 个 特殊 方法 。 在 PHP 中 ， 该 方法 以 ”_construct0 为 方法 
名 ， 而 且 此 方法 没有 返回 值 。 


\y/ 
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构造 函数 的 实质 是 类 中 的 一 个 方法 ， 也 就 是 类 的 一 个 成 员 。 只 不 过 该 方法 和 其 他 方法 
相 比 有 其 特殊 性 。 其 特殊 性 主要 表现 在 以 下 几 个 方面 。 

(1) 构造 函数 必须 命名 为 ”_construct()。 在 PHP 5 以 前 的 版 本 中 ， 构 造 函 数 名 必须 与 
类 名 一 致 ，PHP 5 以 后 改 为 ”_constructO (注意 ，construct 前 面 是 连续 两 条 下 划 线 )。 

(2) 构造 函数 在 类 被 实例 化 时 自动 调用 (用 new 创建 对 象 时 自动 运行 此 方法 )。 

(3) 构造 函数 没有 返回 值 。 

(4) 构造 函数 一 般 不 被 显 式 调用 。 也 就 是 说 构造 函数 在 创建 对 象 时 自动 运行 ， 而 不 需 
要 人 为 去 调用 。 

构造 函数 作为 类 的 基本 特性 之 一 ， 必 然 有 其 用 途 。 构 造 函 数 最 主要 的 用 途 就 是 用 来 实 
现 类 的 初始 化 ， 即 创建 一 个 对 象 的 同时 对 这 个 对 象 进行 一 些 初始 化 操作 ， 而 不 是 等 到 对 象 
创建 完成 后 再 逐个 设置 。 

构造 函数 的 声明 与 其 他 操作 的 声明 一 样 ， 只 是 其 名 称 必 须 是 __constructD)， 这 是 PHP 5 
中 的 变化 。 以 前 的 版 本 中 ,构造 函数 的 名 称 必须 与 类 名 相同 ， 这 在 PHP 5 中 仍然 可 以 沿用 ， 
但 已 经 很 少 有 人 使 用 ， 这 样 做 的 好 处 是 可 以 使 构造 函数 独立 于 类 名 ， 当 类 名 发 生 改变 时 不 
需要 修改 相应 的 构造 函数 名 称 。 为 了 向 下 兼容 , 如 果 一 个 类 中 没有 名 为 ”_constructO 的 方法 ， 
PHP 将 搜索 一 个 PHP 4 中 的 写法 ， 即 与 类 名 同名 的 构造 方法 。 

格式 : 

function ”construct ( [参数 ] ) { .….…} 


在 一 个 类 中 只 能 声明 一 个 构造 方法 ， 而 在 每 次 创建 对 象 时 都 会 调用 一 次 构造 方法 ， 不 
能 主动 地 调用 该 方法 ， 所 以 通常 用 它 执行 一 些 有 用 的 初始 化 任务 ， 如 对 成 员 属性 在 创建 对 
象 时 赋 初 值 。 

【 例 6.8】 


<2php 

/创建 一 个 人 类 

class Person 

/下 面 是 人 的 成 员 属性 

Var $name; /人 的 姓名 

Var $sex; // 人 的 性 别 

Var $age: /人 的 年 龄 

/定义 一 个 构造 方法 ， 参 数 为 姓名 $name、 人 性 别 $sex 和 年 龄 $age 
function _construct($name, $sex, $age) 


{ 

// 通 过 构造 方法 传 进来 的 $name 给 成 员 属 性 $this->name 赋 初 始 值 
S$this->name=$name:; 

// 通 过 构造 方法 传 进来 的 $sex 给 成 员 属 性 $this->sex 赋 初 始 值 
$this->sex=$sex: 

// 通 过 构造 方法 传 进来 的 $age 给 成 员 属性 $this->age 赋 初 始 值 
S$this->age=$age; 


} 
// 这 个 人 的 说 话 方法 ~ 
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function say0O 


{ 

echo "我 的 名 字 叫 :".$this->name.” 性别:".$this->sex." 我 的 年 龄 是 : 
".$this->age."<br>"; 

} 


} 

// 通 过 构造 方法 创建 3 个 对 象 Spl1、$p2、$p3， 分 别传 入 3 个 不 同 的 实 参 : 姓名 、 性 别 和 年 龄 
$pl=new Person(" 张 三 "，" 男 ", 20); 
$p2=new Person(" 李 四 "，" 女 ", 30); 
$p3=new Person(" 王 五 "，" 男 ", 40); 
/下 面 访 问 $pl 对 象 中 的 说 话 方法 
3$p1->say0; 

// 下 面 访问 $p2 对 象 中 的 说 话 方法 
3$p2->say(; 

/下 面 访问 $p3 对 象 中 的 说 话 方法 
$p3->sayO; 

?> 


输出 结果 为 : 


我 的 名 字 叫 : 张 三 性 别 : 男 我 的 年 龄 是 : 20 
我 的 名 字 叫 : 李 四 性 别 : 女 我 的 年 龄 是 : 30 
我 的 名 字 叫 : 王 五 性 别 : 男 我 的 年 龄 是 : 40 


6.2.2” 析 构 函 数 


与 构造 函数 相对 的 就 是 析 构 函数 。 析 构 函 数 是 PHP 5 新 添加 的 内 容 ， 它 允许 在 销毁 一 
个 类 之 前 执行 一 些 操作 或 完成 一 些 功能 ， 如 关闭 文件 、 释 放 结果 集 等 。 析 构 函 数 会 在 某 个 
对 象 的 所 有 引用 都 被 删除 或 者 当 对 象 被 显 式 销毁 时 执行 ， 也 就 是 对 象 在 内 存 中 被 销毁 前 调 
用 析 构 函数 。 与 构造 函数 的 名 称 类 似 ， 一 个 类 的 析 构 函数 名 称 必 须 是 __destruct0。 析 构 函 
数 没 有 参数 和 返回 值 。 析 构 函数 在 对 象 被 销毁 时 自动 调用 ， 一 般 不 需要 显 式 调用 。 

格式 : 

function __destruct 0 {...} 


【 例 6.9】 


<2php 
/创建 一 个 人 类 


class Person 


/下 面 是 人 的 成 员 属性 

Var $name; // 人 的 姓名 

Var $sex; /人 的 性 别 

Var $age; /人 的 年 龄 

/定义 一 个 构造 方法 ， 参 数 为 姓名 $name、 人 性 别 $sex 和 年 龄 $age 
function _construct($name, $sex, $age) 


\y/ { 
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// 通 过 构造 方法 传 进来 的 $name 给 成 员 属性 $this->name 赋 初 始 值 
S$this->name=$name: 

// 通 过 构造 方法 传 进来 的 $sex 给 成 员 属 性 $this->sex 赋 初 始 值 
S$this->sex=$sex:; 

// 通 过 构造 方法 传 进来 的 $age 给 成 员 属 性 $this->age 赋 初始 值 
S$this->age=$age; 


上 
/这 个 人 的 说 话 方法 
function sayO 


{ 
echo "我 的 名 字 叫 :".$this->name.” 性 别 :".$this->sex.” 我 的 年 龄 是 : 
".$this->age."<br>"; 


上 
/这 是 一 个 析 构 函数 ， 在 对 象 销 毁 前 调用 
function destructO 


echo "再 见 ".$this->name. "<br>"; 


} 

// 通 过 构造 方法 创建 3 个 对 象 Spl1、$p2、$p3， 分 别传 入 3 个 不 同 的 实 参 : 姓名、 性 别 和 年 龄 
$pl=new Person(" 张 三 "，" 男 ", 20); 
$p2=new Person(" 李 四 "，" 女 ", 30); 
$p3=new Person(" 王 五 "，" 男 ", 40); 
/下 面 访 问 $pl 对 象 中 的 说 话 方法 
$p1->say(); 

/下面 访问 $p2 对 象 中 的 说 话 方法 
$p2->sayO); 

/下 面 访问 $p3 对 象 中 的 说 话 方法 
$p3->sayQ; 

?> 


输出 结果 为 : 


我 的 名 字 叫 : 张 三 性 别 : 男 我 的 年 龄 是 : 20 
我 的 名 字 叫 : 李 四 性 别 ， 女 我 的 年 龄 是 ，30 
我 的 名 字 叫 : 王 五 性 别 : 男 我 的 年 龄 是 : 40 
再 见 张 三 

再 见 李 四 

再 见 王 五 

练习 

1. 简 述 构造 函数 的 特点 。 

2. 简 述 析 构 函数 的 特点 。 


任务 3 关 的 基本 应 用 


任务 描述 
了 解 类 与 对 象 的 基本 应 用 与 特点 ， 掌 握 类 与 对 象 的 应 用 方法 。 \ 7/ 
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疙 


知识 汇总 
6.3.1 封装 性 


封装 性 是 面向 对 象 编程 中 的 三 大 特性 之 一 。 所 谓 封装 性 ， 就 是 把 对 象 的 属性 和 服务 结 
合成 一 个 独立 的 相同 单位 ， 并 尽 可 能 隐蔽 对 象 的 内 部 细节 ， 包 含 两 个 含义 : 一 是 把 对 象 的 
全 部 属性 和 全 部 服务 结合 在 一 起 ， 形 成 一 个 不 可 分 割 的 独立 单位 〈 即 对 象 ) ; 二 是 信息 隐 
蔽 ， 即 尽 可 能 隐蔽 对 象 的 内 部 细节 ， 对 外 形成 一 个 边界 〈 或 者 说 形成 一 道 屏障 ) ， 只 保留 
有 限 的 对 外 接口 使 之 与 外 部 发 生 联 系 。 

封装 的 原则 在 软件 上 的 反应 是 : 要 求 使 对 象 以 外 的 部 分 不 能 随意 存 取 对 象 的 内 部 数据 
(属性 ) ， 从 而 有 效 地 避免 了 外 部 错误 对 它 的 “交叉 感染 ”， 使 软件 错误 能 够 局 部 化 ， 大 
大 减少 查 错 和 排 错 的 难度 。 

例如 ,假设 某 个 人 的 对 象 中 有 年 龄 和 工资 等 属性 ， 像 这 样 涉及 个 人 隐私 的 属性 是 不 想 让 
其 他 人 随意 获得 的 ， 使 用 封装 之 后 ， 别 人 就 没有 办 法 获得 封装 的 属性 ， 除 非 你 自己 把 它 说 


出 去 。 
- 般 使 用 private 关键 字 来 对 属性 和 方法 进行 封装 。 
原来 的 成 员 : 
Var $sex; // 声 明 人 的 性 别 
Var $age; // 声 明 人 的 年 龄 
function rnO{... ... .} 
改 成 封装 的 形式 : 
private $name; /把 人 的 姓名 使 用 private 关键 字 进 行 封装 
private $sex: 1// 把 人 的 性 别 使 用 private 关键 字 进 行 封装 
private $age; // 把 人 的 年 龄 使 用 private 关键 字 进 行 封装 
private function ranO){** … // 把 人 的 走路 方法 使 用 private 关键 字 进行 封装 


[EE | 
人 属 | 性 前 面 有 其 他 的 关键 字 ， 就 要 去 择 原 有 的 关键 字 vw Var 


通过 private 就 可 以 把 人 的 成 员 (成 员 属性 和 成 员 方 法 ) 封装 上 了 。 封装 上 的 成 员 不 能 
被 类 外 面 直接 访问 ， 只 有 对 象 内 部 可 以 访问 。 例 6.10 中 的 代码 会 产生 错误 。 
【 例 6.10】 


class Person 


{ 

/下 面 是 人 的 成 员 属性 

Private $name; /人 的 姓名 ， 被 private 封装 上 了 

private $sex; /人 的 性 别 ， 被 private 封装 上 了 

Private $age; /人 的 年 龄 ， 被 private 封装 上 了 
Wh /这 个 人 可 以 说 话 的 方法 
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function sayO 

{ 

echo "我 的 名 字 叫 :".$this->name."” 性 别 :".$this->sex." 我 的 年 龄 是 : 
".$this->age."<br>"; 


上 

/这 个 人 可 以 走路 的 方法 ， 被 private 封装 上 了 
Private function run() 

echo "这 个 人 在 走路 "; 

} 


} 

/实例 化 一 个 人 的 实例 对 象 

$pl=new Person(); 
/试图 去 给 私有 的 属性 赋值 ， 结 果 会 发 生 错误 
$p1->name=" 张 三 "; 

$p1->sex=" 男 "; 

$p1->age=20; 

/试图 去 打印 私有 的 属性 ， 结 果 会 发 生 错误 
echo $p1->name. "<br>"; 

echo $p1->sex. "<br>"; 

echo $p1->age. "<br>" 

// 试 图 去 打印 私有 的 成 员 方 法 ， 结 果 会 发 生 错误 
$p1->runO); 


输出 结果 为 : 


Fatal error: Cannot access private property Person::$name 
Fatal error: Cannot access private property Person::$sex 
Fatal error: Cannot access private property Person::$age 
Fatal error: Cannot access private property Person::$name 
Fatal error: Call to private method Person::run() from context 


从 例 6.10 可 以 看 到 ， 私 有 的 成 员 是 不 能 被 外 部 访问 的 ， 因 为 私有 成 员 只 能 在 本 对 象 内 
部 访问 ， 比 如 Spl 这 个 对 象 想 把 他 的 私有 属性 说 出 去 ， 在 say0 方 法 里 面 访问 了 私有 属性 ， 
这 样 是 可 以 的 (没有 加 任何 访问 控制 ， 默 认为 public ， 任 何 地方 都 可 以 访问 ) 。 


/这 个 人 可 以 说 话 的 方法 ， 说 出 自己 的 私有 属性 ， 在 这 里 也 可 以 访问 私有 方法 
function sayO 


{ 

echo "我 的 名 字 叫 : ".$this->name." 性 别 : ".$this->sex." 我 的 年 龄 是 : 
".$this->age."<br>"; 

/在 这 里 也 可 以 访问 私有 方法 

/this->run0); 

} 


因为 成 员 方 法 say0 是 公有 的 ， 所 以 在 类 的 外 部 调用 say0 方 法 是 可 以 的 ， 如 例 6.11 所 
示 ， 改 变 例 6.10 中 的 代码 。 
【 例 6.11】 


class Person 
{ 所 
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/下 面 是 人 的 成 员 属 性 

Private $name; /人 的 姓名 ， 被 private 封装 上 了 
private $sex; /人 的 性 别 ， 被 private 封装 上 了 
Private $age; /人 的 年 龄 ， 被 private 封装 上 了 


// 定 义 一 个 构造 方法 ， 参 数 为 私有 的 属性 姓名 $name、 性 别 $sex 和 年 龄 $age 进行 赋值 
function _ _construct($name, $sex, $age) 


{ 

// 通 过 构造 方法 传 进来 的 $name 给 私有 成 员 属 性 $this->name 赋 初 始 值 
S$this->name=$name:; 

// 通 过 构造 方法 传 进来 的 $sex 给 私有 成 员 属性 $this->sex 赋 初 始 值 
S$this->sex=$sex; 

// 通 过 构造 方法 传 进来 的 $age 给 私有 成 员 属 性 $this->age 赋 初 始 值 
Sthis->age=$age; 

. 

// 这 个 人 可 以 说 话 的 方法 ， 说 出 自己 的 私有 属性 ， 在 这 里 也 可 以 访问 私有 方法 
function say() 

{ 

echo "我 的 名 字 叫 :".$this->name.” 性 别 :".$this->sex.” 我 的 年 龄 是 : 
".$this->age."<br>"; 

) 

// 通 过 构造 方法 创建 3 个 对 象 $p1、$p2、$p3， 分 别传 入 3 个 不 同 的 实 参 : 姓名、 性 别 和 年 龄 
$pl=new Person(" 张 三 "，" 男 ", 20); 

$p2=new Person(" 李 四 "，" 女 ", 30); 

$p3=new Person(" 王 五 "，" 男 ", 40); 

/下 面 访问 $pl 对 象 中 的 说 话 方法 

$p1->say(); 

// 下 面 访 问 $p2 对 象 中 的 说 话 方法 

$p2->say(0; 

/下 面 访问 $p3 对 象 中 的 说 话 方法 

$p3->say(); 


输出 结果 为 : 


我 的 名 字 叫 : 张 三 性 别 : 男 我 的 年 龄 是 ，20 

我 的 名 字 叫 : 李 四 性 别 : 女 我 的 年 龄 是 : 30 

我 的 名 字 叫 : 王 五 性 别 : 男 我 的 年 龄 是 : 40 

内 为 构造 方法 是 默认 的 公有 方法 构造 方 法 不 要 设置 成 私有 的 ) ， 所 以 在 类 的 外 面 可 
以 访问 到 ， 这 样 就 可 以 使 用 构造 方法 创建 对 象 。 另 外 ， 构 造 方 法 也 是 类 里 面 的 函数 ， 所 以 
可 以 用 构造 方法 给 私有 的 属性 赋 初 值 。say0 方 法 是 默认 公有 的 ， 所 以 在 外 面 也 可 以 访问 到 ， 
说 出 它 自己 的 私有 属性 。 

从 上 面 的 例子 中 可 以 看 到 ， 私 有 的 成 员 只 能 在 类 的 内 部 使 用 ， 不 能 被 类 外 部 直接 来 存 

取 ， 但 是 在 类 的 内 部 是 有 权限 访问 的 ， 所 以 有 时 需要 在 类 的 外 面 给 私有 属性 赋值 和 读 取出 
来 ， 也 就 是 给 类 的 外 部 提供 一 些 可 以 存 取 的 接口 。 例 6.11 中 的 构造 方法 就 是 一 种 赋值 的 形 
式 ， 但 是 构造 方法 只 是 在 创建 对 象 时 赋值 ， 如 果 已 经 有 一 个 存在 的 对 象 ， 想 对 其 赋值 ， 这 
时 如 果 还 使 用 构造 方法 传 值 的 形式 传 值 ， 那 么 就 创建 了 一 个 新 的 对 象 ， 并 不 是 这 个 已 存在 

ci 的 对 象 了 。 所 以 要 对 私有 的 属性 做 一 些 可 以 被 外 部 存 取 的 接口 ， 目 的 就 是 可 以 在 对 象 存在 
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的 情况 下 ， 改 变 和 存 取 属性 的 值 。 但 要 注意 ， 只 有 需要 让 外 部 改变 的 属性 时 才 这 样 做 ， 不 
想 让 外 面 访问 的 属性 是 不 做 这 样 的 接口 的 ， 这 样 就 能 达到 封装 的 目的 ， 所 有 的 功能 都 是 对 
象 自己 来 完成 ， 给 外 面 提供 尽量 少 的 操作 。 

如 果 给 类 外 部 提供 接口 ， 可 以 为 私有 属性 在 类 外 部 提供 设置 方法 和 获取 方法 ， 来 操作 
私有 属性 。 下 面 举例 说 明 。 

【 例 6.12】 
private $age; /私有 的 属性 年 龄 
function setAge($age) /为 外 部 提供 一 个 公有 设置 年 龄 的 方法 


if($age<0 || $age>130) // 在 给 属性 赋值 时 ， 为 了 避免 非法 值 设置 给 属性 
return; 

S$this->age=$age; 

} 

function getAgeO // 为 外 部 提供 一 个 公有 获取 年 龄 的 方法 

{ 

return($this->age); 

¥ 


上 面 的 方法 是 为 一 个 成 员 属性 设置 和 获取 值 ， 当 然 也 可 以 为 每 个 属性 用 同样 的 方法 进 
行 赋值 和 取 值 操作 ， 完 成 在 类 外 部 的 存 取 工 作 。 


6.3.2 set0、_ get0、_isset0、_unset04 个 方法 的 应 用 


- 般 来 说 ， 总 是 把 类 的 属性 定义 为 private， 这 更 符合 现实 的 逻辑 。 但 是 ， 对 属性 的 读 
取 和 赋值 操作 是 非常 频繁 的 ， 因 此 在 PHP 5 中 ， 预 定义 了 两 个 方法 ”get0 和 set0 来 获取 
和 赋值 属性 。 另 外 ， 还 有 检查 属性 的 方法 _isset0 和 删除 属性 的 方法 _unsetO。 

6.3.1 节 中 ， 我 们 为 每 个 属性 做 了 设置 和 获取 的 方法 ,在 PHP 5 中 为 用 户 提供 了 专门 为 
属性 设置 和 获取 值 的 方法 一 一 _set0 和 __get0， 这 两 个 方法 不 是 默认 存在 的 ， 而 是 需要 手 
工 添加 到 类 中 ， 像 构造 方法 __construct0 一 样 ， 在 类 中 进行 添加 才 会 存在 ， 可 以 按 下 面 的 方 
式 来 添加 这 两 个 方法 ， 当 然 也 可 以 按 个 人 的 风格 来 添加 。 

//_get0 方 法 用 来 获取 私有 属性 

private function get($property_name) 


ifisset($this->$property_name)) 


return($this->$property_name); 
}else 


{ 

return(NULL); 

上 

} 

//_ set0 方 法 用 来 设置 私有 属性 

private function _set($property_name, $value) 

{ 坟 、 攻 


全 一 . -高 等 职业 教育 “十 二 五 " 规划 教材 一 > - 


-项 目 6 ”PHP 面向 对 象 编程 轩 2 


$this->$property_ name = $value; 

} 

1 .gel( 沪 法 

_ get() 方 法 用 来 获取 私有 成 员 属 性 值 ， 该 方法 有 一 个 参数 ， 用 于 传 入 要 获取 的 成 员 属 
性 的 名 称 ， 返 回 获 取 的 属性 值 。_get( 方 法 不 用 手工 调用 ， 因 为 可 以 把 其 做 成 私有 的 方法 ， 
是 在 直接 获取 私有 属性 时 对 象 自动 调用 的 。 因 为 私有 属性 已 经 被 封装 ， 是 不 能 直接 获取 值 
的 (如 echo $p1->name 这 样 直接 获取 是 错误 的 ) ， 但 是 如 果 在 类 里 面 加 上 get0 方 法 ， 在 使 
用 echo $pl->name 语句 直接 获取 值 时 就 会 自动 调用 ”get($property_ name) 方 法 ， 将 属性 
name 传 给 参数 $property_ name， 通 过 该 方法 的 内 部 执行 ， 返 回 传 入 的 私有 属性 的 值 。 如 果 
成 员 属 性 不 封装 成 私有 的 ， 对 象 本 身 就 不 会 去 自动 调用 这 个 方法 。 

2. _set() 方 法 

__set() 方 法 用 来 为 私有 成 员 属性 设置 值 ， 该 方法 有 两 个 参数 ， 第 一 个 参数 为 要 设置 值 
的 属性 名 ， 第 二 个 参数 是 要 给 属性 设置 的 值 ， 没 有 返回 值 。 该 方法 同样 不 用 手工 调用 ， 它 
也 可 以 做 成 私有 的 ， 是 在 直接 设置 私有 属性 值 时 自动 调用 的 。 同 样 ， 私 有 属性 已 经 被 封装 ， 
如 果 没 有 _ set0 方 法 ， 是 不 允许 被 赋值 的 ， 如 S$this->name='zhangsanm' 语 句 会 出 错 ， 但 是 如 果 
在 类 里 面 加 上 set($property_name, $value) 方 法 , 在 直接 给 私有 属性 赋值 时 ， 就 会 自动 调用 
该 方法 ， 把 属性 (如 name) 传 给 Sproperty_name， 把 要 赋 的 值 zhangsan 传 给 $value， 通 过 
这 个 方法 的 执行 ， 达 到 赋值 的 目的 。 如 果 成 员 属 性 不 封装 成 私有 的 ， 对 象 本 身 就 不 会 去 自 
动 调用 这 个 方法 。 为 了 不 传 入 非法 的 值 ， 还 可 以 用 这 个 方法 给 做 一 下 判断 。 

【 例 6.13】 


<2php 
class Person 


长 
/下 面 是 人 的 成 员 属性 ， 都 是 封装 的 私有 成 员 


Private $name; /人 的 姓名 
private $sex; /人 的 性 别 
Private $age; /人 的 年 龄 
//_get0 方 法 用 来 获取 私有 属性 


Private function get($property_name) 


{ 
echo "在 直接 获取 私有 属性 值 的 时 候 ， 自 动 调用 了 这 个 _get0 方 法 <br>"; 
ifisset($this->$property_ name)) 


return($this->$property_name); 
}ye 


lse 


{ 
return(NULL); 
上 


} 

//_set0 方 法 用 来 设置 私有 属性 

private function _set($property_name, $value) 
7 { 
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echo "在 直接 设置 私有 属性 值 的 时 候 ， 自 动 调用 了 这 个 _set0 方 法 为 私有 属性 赋值 <br>"; 
Sthis->$property_name = $value; 

} 

} 

S$pl=new Person(); 

// 直 接 为 私有 属性 赋值 的 操作 ， 会 自动 调用 _set0 方 法 进行 赋值 
$p1->name" 张 三 "; 

$p1->sex=" 男 "; 

$p1->age=20: 

/直接 获取 私有 属性 的 值 ， 会 自动 调用 _ get0 方 法 ， 返 回 成 员 属性 的 值 
echo "姓名 : ".$p1->name."<br>": 

echo "性 别 : ".$p1->sex."<br>"; 

echo "年 龄 : ".$p1->age."<br>"; 

VE 


程序 执行 结果 : 

在 直接 设置 私有 属性 值 的 时 候 ， 自 动 调用 了 这 个 _set0 方 法 为 私有 属性 赋值 

在 直接 设置 私有 属性 值 的 时 候 ， 自 动 调用 了 这 个 _set0 方 法 为 私有 属性 赋值 

在 直接 设置 私有 属性 值 的 时 候 ， 自 动 调用 了 这 个 _set0 方 法 为 私有 属性 赋值 

在 直接 获取 私有 属性 值 的 时 候 ， 自 动 调用 了 这 个 _get0 方 法 

姓名 : 张 三 

在 直接 获取 私有 属性 值 的 时 候 ， 自 动 调用 了 这 个 _get0 方 法 

性 别 : 男 

在 直接 获取 私有 属性 值 的 时 候 ， 自 动 调用 了 这 个 _ get( 方 法 

年 龄 : 20 

以 上 代码 如 果 不 加 入 _get0 和 _ set() 方 法 ， 程 序 就 会 出 错 ， 因 为 不 能 在 类 的 外 部 操作 
私有 成 员 ， 而 上 面 的 代码 是 通过 自动 调用 _get0 和 __set() 方 法 来 帮助 用 户 直 接 存 取 封 装 的 
私有 成 员 的 。 

3. _isset() 方 法 


在 看 这 个 方法 之 前 先 看 一 下 issetO 函 数 的 应 用 。isset0 是 测定 变量 是 否 被 设 定 用 的 函数 ， 
传 入 一 个 变量 作为 参数 ， 如 果 传 入 的 变量 存在 则 传 回 TRUE， 和 否则 传 回 FALSE。 那 么 可 不 
可 以 在 一 个 对 象 外 面 使 用 issetO 函 数 去 测定 对 象 里 面 的 成 员 是 否 被 设 定 呢 ? 分 两 种 情况 ; 
如 果 对 象 里 面 成 员 是 公有 的 ， 可 以 使 用 该 函数 来 测定 成 员 属 性 ; 如果 是 私有 的 成 员 属 性 ， 
该 函数 就 不 起 作用 了 。 原 因 就 是 私有 属性 被 封装 了 ， 在 外 部 不 可 见 。 若 想 要 在 对 象 的 外 部 
使 用 isset0 函 数 来 测定 私有 成 员 属 性 是 否 被 设 定 ， 只 要 在 类 里 面 加 上 __isset() 方 法 即 可 。 当 
在 类 外 部 使 用 isset0) 函 数 来 测定 对 象 里 面 的 私有 成 员 是 否 被 设 定时 ， 就 会 自动 调用 类 里 面 
的 _isset() 方 法 来 完成 这 样 的 操作 。__isset() 方 法 也 可 以 做 成 私有 的 ， 在 类 里 面 加 上 下 面 的 
代码 即 可 : 


Private function _ isset($nm) 


{ 
echo " 当 在 类 外 部 使 用 isset0 函 数 测定 私有 成 员 $nm 时 ， 自 动 调用 <br>"; 
Tetum isset($this->$nm):; 


} NT1 
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4. unset(0 方 法 


学 习 _unset() 方 法 之 前 , 先 来 看 一 下 unset0 这 个 函数 。unset0 函 数 的 作用 是 删除 指定 的 
变量 上 且 传 回 TRUE， 参 数 为 要 删除 的 变量 。 那 么 可 不 可 以 在 一 个 对 象 外 部 使 用 unset0 函 数 
删除 对 象 内 部 的 成 员 属性 呢 ? 也 是 分 两 种 情况 : 如 果 一 个 对 象 里 面 的 成 员 属性 是 公有 的 ， 
就 可 以 使 用 该 函数 在 对 象 外 面 删除 对 象 的 属性 ; 如 果 对 象 的 成 员 属 性 是 私有 的 ， 使 用 该 函 
数 就 没有 权限 去 删除 。 但 同样 ， 如 果 在 一 个 对 象 里 面 加 上 _unset0 方 法 ， 就 可 以 在 对 象 的 
外 部 删除 对 象 的 私有 成 员 属 性 了 。 在 对 象 里 面 加 上 unset0 方 法 之 后 ， 在 对 象 外 部 使 用 
unset0 函 数 删 除 对 象 内 部 的 私有 成 员 属 性 时 , 将 自动 调用 _unset0 方 法 来 帮助 我 们 删除 对 象 
内 部 的 私有 成 员 属 性 。 该 方法 也 可 以 在 类 的 内 部 定义 成 私有 的 ， 在 对 象 里 面 加 上 下 面 的 代 
码 即 可 : 


private function _ unset($nm) 

{ 

echo " 当 在 类 外 部 使 用 unset0 函 数 来 删除 私有 成 员 时 自动 调用 <br>"; 
unset($this->$nm); 


} 


下 面 来 看 一 个 完整 的 实例 。 
【 例 6.14】 


<2php 
class Person 


/下 面 是 人 的 成 员 属性 

private $name; /人 的 姓名 
private $sex; /人 的 性 别 
private $age; /人 的 年 龄 
/1/_ get0 方 法 用 来 获取 私有 属性 

private function __get($property_name) 
ifisset($this->$property_name)) 

后 

return($this->$property_name); 

Yelse { 

return(NULL); 

} 


} 
//_set0 方 法 用 来 设置 私有 属性 
private function __set($property_name, $value) 
{ 
S$this->$property_name = $value; 
和 
//_isset0 方 法 
Private function _ isset($nm) 
{ 
Ne echo "isset0 函 数 测定 私有 成 员 时 ， 自 动 调用 <br>"; 
/ 
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疙 一 


Tetum isset($this->$nm); 

上 

//_unset0 方 法 

private function __ unset($nm) 


{ 

echo " 当 在 类 外 部 使 用 unset0 函 数 来 删除 私有 成 员 时 自动 调用 <br>"; 

unset($this->$nm); 

} 

} 

$pl=new Person(); 

$p1->name="this is a person name"; 

/在 使 用 issetO 函 数 测定 私有 成 员 时 ， 自 动 调用 _ isset0 方 法 帮 有 我 们 完成 ， 返 回 结果 为 TRUE 
echo var_dump(isset($p1->name))."<br>"; 

echo $p1->name."<br>"; 

/在 使 用 unsetO 函 数 删 除 私有 成 员 时 ， 自 动 调用 _unset( 方 法 帮 我 们 完成 ， 删 除 name 私有 属性 
unset($p1->name); 

// 已 经 被 删除 了 ， 所 以 这 行 不 会 有 输出 

echo $pl1->name; 

x 


isset0 函 数 测定 私有 成 员 时 ， 自 动 调用 
bool(tme) 
this is a person name 
当 在 类 外 部 使 用 unset0 函 数 来 删除 私有 成 员 时 自动 调用 
set()、 get()、_isset()、__unset0 这 4 个 方法 都 是 用 户 添加 到 对 象 里 面 的 ， 在 需要 
时 可 自动 调用 ， 来 完成 在 对 象 外 部 对 对 象 内 部 私有 属性 的 操作 。 


6.3.3 类 的 继承 


继承 作为 面向 对 象 的 三 个 重要 特性 的 一 个 方面 ， 在 面向 对 象 的 领域 有 着 极其 重要 的 作 
用 ， 所 有 面向 对 象 的 语言 都 支持 继承 。 继 承 是 PHP 5 面向 对 象 程序 设计 的 重要 特性 之 一 ， 
它 是 指 建 立 一 个 新 的 派生 类 ， 从 一 个 或 多 个 先前 定义 的 类 中 继承 数据 和 函数 ， 而 且 可 以 重 
新 定义 或 加 进 新 数据 和 函数 ， 从 而 建立 类 的 层次 或 等 级 。 简 单 地 说 ， 继 承 性 是 子 类 自动 共 
享 父 类 的 数据 结构 和 方法 的 机 制 ， 这 是 类 之 间 的 一 种 关系 。 在 定义 和 实现 一 个 类 时 ， 可 以 
在 一 个 已 经 存在 的 类 的 基础 之 上 来 进行 ， 把 这 个 已 经 存在 的 类 所 定义 的 内 容 作为 自己 的 内 
容 ， 并 加 入 若干 新 的 内 容 。 比 如 现在 已 经 有 一 个 “人 ”类 ， 该 类 里 面 有 两 个 成 员 属 性 〈 姓 
名 和 年 龄 ) 和 两 个 成 员 方法 〈 说 话 的 方法 和 走路 的 方法 ) ， 如 果 现 在 程序 需要 一 个 学 生 类 ， 
因为 学 生 也 是 人 ， 所 以 学 生 也 有 成 员 属性 (姓名 和 年 龄 》 以 及 成 员 方 法 (说 话 的 方法 和 走 
路 的 方法 ) ， 这 时 就 可 以 让 学 生 类 来 继承 人 这 个 类 。 继 承 之 后 ， 学 生 类 就 会 把 人 类 里 面 的 
所 有 属性 都 继承 过 来 ， 省 去 了 重新 声明 一 遍 这 些 成 员 属 性 和 方法 。 因 为 学 生 类 里 面 还 有 所 
在 学 校 的 属性 和 学 习 的 方法 ， 所 以 加 上 学 生 特 有 的 所 在 学 校 属 性 和 学 习 的 方法 ， 这 样 一 个 
学 生 类 就 声明 完成 了 。 继 承 也 可 以 叫做 “扩展 ”， 从 上 面 的 例子 可 以 看 出 ， 学 生 类 对 人 类 


\ 
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进行 了 扩展 ， 在 人 类 里 原 有 两 个 属性 和 两 个 方法 的 基础 上 加 上 一 个 属性 和 一 个 方法 就 扩展 
出 来 一 个 新 的 学 生 类 。 

通过 继承 机 制 ， 可 以 利用 已 有 的 数据 类 型 来 定义 新 的 数据 类 型 。 所 定义 的 新 的 数据 类 
型 不 仅 拥有 新 定义 的 成 员 ， 而 且 还 同时 拥有 旧 的 成 员 。 我 们 称 已 存在 的 用 来 派生 新 类 的 类 
为 基 类 ， 又 称 为 父 类 或 超 类 。 由 已 存在 的 类 派生 出 的 新 类 称 为 派生 类 ， 又 称 为 子 类 。 
在 软件 开发 中 ， 类 的 继承 性 使 所 建立 的 软件 具有 开放 性 、 可 扩充 性 ， 这 是 信息 组 织 与 
分 类 的 行 之 有 效 的 方法 ， 它 简化 了 对 象 、 类 的 创建 工作 ， 增 加 了 代码 的 可 重 性 。 采 用 继承 
性 ， 提 供 了 类 的 规范 的 等 级 结构 。 通 过 类 的 继承 关系 ， 使 公共 的 特性 能 够 共享 ， 提 高 了 软 
件 的 重用 性 。 
在 PHP 和 Java 语言 里 面 没有 多 继承 ， 只 有 单 继 承 。 也 就 是 说 ， 一 个 类 只 能 直接 从 一 
个 类 中 继承 数据 。 在 PHP 中 ， 要 实现 继承 ， 只 需要 在 类 定义 时 使 用 extends 关键 字 ， 即 可 
让 该 类 继承 自 另外 一 个 类 ， 从 而 拥有 它 所 继承 的 类 的 全 部 特征 。 下 面 看 一 个 实例 。 
【 例 6.15】 


<?php 

class Dog{ 

Var $weight; 

function go0{ 

echo " 狗 跑 起 来 了 一 <br>"; 

} 

} 

class shepherdDog extends Dog{ // 用 extends 关键 字 声 明 本 类 自 Dog 类 派生 而 来 
Var $speed; 

function followO{ 

echo "牧羊 犬 (体重 ".$this->weight.") 在 跟踪 羊 群 ."; 
echo "(速度 ".$this->speed."kmy/h)<br>"; 

} 

} 

$dog = new shepherdDog():; 

$dog->weight=150; 

$dog->speed =30; 

$dog->go0; 

$dog->follow(); 

Px 


下 面 来 分 析 一 下 本 程序 。 

第 2 一 7 行 定义 了 一 个 狗 类 Dog。 

第 8 一 14 行 定义 了 一 个 牧羊 犬 类 shepherdDog， 并 在 类 声明 中 使 用 extends 关键 字 ， 声 
明 本 类 是 从 Dog 类 继承 而 来 ， 那 么 shepherdDog 类 就 是 Dog 类 的 子 类 ，Dog 类 是 父 类 。 

第 15 行 创建 了 一 个 shepherdDog 类 的 对 象 $dog。 

第 16 一 19 行 分 别 调用 $dog 对 象 的 2 个 变量 和 2 个 方法 。 

虽然 该 程序 并 不 复杂 ， 但 是 足以 表明 继承 的 作用 。 如 果 shepherdDog 类 没有 声明 为 继 


承 自 Dog 类 ， 那 么 该 类 就 不 可 能 拥有 除了 $speed 变量 和 follow0 方 法 之 外 的 成 员 。 但 是 本 
NT 7/ 
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例 中 ，shepherdDog 类 声明 为 继承 自 Dog， 那 么 Dog 类 的 所 有 成 员 一 一 $weight 变量 和 go() 
方法 都 被 继承 到 了 子 类 shepherdDog 中 ， 可 以 直接 使 用 。 

旦 使 用 extends 关键 字 声 明 一 个 类 B 继承 自 另 外 一 个 类 A， 那 么 类 B 就 继承 了 类 A 
的 所 有 成 员 ( 父 类 中 声明 为 private 的 除外 )。 其 中 包括 类 A 从 它 的 父 类 中 继承 下 来 的 成 员 。 
这 就 是 继承 的 核心 特点 。 掌 握 了 继承 的 概念 ， 就 可 以 在 很 多 场合 灵活 运用 ， 来 解决 编程 中 
的 实际 问题 。 

最 后 需要 说 明 的 一 点 是 ， 并 不 是 所 有 的 类 都 可 以 被 其 他 类 继承 。 如 果 一 个 类 不 希望 被 
其 他 类 继承 ， 可 以 在 声明 此 类 时 在 前 面 增加 final 关键 字 。 
final class BaseClass { // 此 类 声明 为 final 最 终 类 


public function testO { 
echo "just a test"; 


} 
} 
class ChildClass extends BaseClass { // 报 错 ， 因 为 声明 为 final 的 类 不 能 被 继承 
} 
如 果子 类 中 定义 了 和 父 类 重 名 的 成 员 ， 会 有 什么 后 果 呢 ? 这 就 是 下 一 节 将 要 讨论 的 问 
6.3.4 和 覆盖 与 重 载 
1. 和 覆盖 


一 个 类 B 继承 另外 一 个 类 A 时 ， 如 果 B 中 定义 的 成 员 与 A 中 定义 的 成 员 发 生 重 名 ， 
则 产生 履 盖 ， 即 B 中 的 成 员 获 盖 A 中 的 同名 成 员 。 

补益 可 以 是 变量 ， 也 可 以 是 方法 ， 故 称 又 成 员 窗 盖 。 

【 例 6.16】 


<2php 

class Dog{ 
public $speed=60; 
public $weight=100; // 变 量 名 为 $weight 
public function goO{ /方法 名 为 go0 
echo " 狗 跑 起 来 了 。"; 
} 
} 
class shepherdDog extends Dog{ 
public $weight=150; // 变 量 名 重复 
public function go0{ // 方 法 名 与 父 类 发 生 重 
echo "牧羊 犬 在 跟踪 羊 群 ."; 
} 


| 
内 


} 
$dog = new shepherdDog(); 
echo $dog->weight: 
$dog->go0): 


?> \Y1/ 
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由 输出 结果 看 出 ， 当 子 类 中 的 成 员 与 父 类 中 的 成 员 重 名 时 ， 子 类 中 的 成 员 覆 盖 掉 父 类 
中 的 成 员 。 即 当 使 用 子 类 对 象 调用 重 名 的 成 员 时 ， 实 际 调用 的 是 子 类 的 成 员 ， 子 类 虽然 继 
承 了 父 类 的 同名 成 员 ， 但 是 父 类 中 的 成 员 被 覆盖 掉 了 。 

本 程序 只 是 介绍 了 最 基本 的 履 盖 情况 。 方 法 的 覆盖 也 有 一 些 特殊 情况 , 如 声明 为 private 
的 成 员 由 于 无 法 被 继承 ， 因 此 也 不 可 能 被 覆盖 。 此 外 ， 子 类 的 方法 调用 父 类 方法 、 父 类 方 
法 调用 自身 方法 等 情况 下 ， 产 生 的 覆盖 问题 也 错综复杂 。 本 书 对 这 些 问题 不 做 深入 讨论 ， 
对 此 感 兴趣 的 读者 可 以 参考 PHP 手册 进一步 研究 。 

2.， 重 载 

重 载 (Overloading〉 是 面向 对 象 的 编程 语言 三 大 特性 之 一 一 一 多 态 的 重要 表现 形式 。 
重 载 可 以 用 一 句 话 简单 概括 : 在 同一 个 类 中 出 现 同名 的 变量 或 方法 。 

实际 上 , 纯粹 的 面向 对 象 编程 语言 都 对 重 载 有 良好 的 支持 。PHP 作为 一 门 Web 编程 语 
言 ， 对 重 载 的 支持 并 不 理想 ， 甚 至 可 以 说 PHP 根本 不 支持 真正 的 重 载 。 因 为 PHP 不 允许 
一 个 类 中 出 现 两 个 同名 的 变量 或 者 同名 的 方法 ， 否 则 会 报错 。 但 是 PHP 通过 几 个 所 谓 的 
“Magic methods〈 魔 法 方法 )” 实 现 了 变相 的 重 载 。 在 PHP 手册 关于 PHP 5 面向 对 象 编程 
的 介绍 中 ， 就 有 重 载 一 节 。 但 是 很 明显 ， 这 种 重 载 方法 只 是 低层 次 的 。 

虽然 采用 一 些 方法 可 以 实现 一 定 意义 上 的 重 载 ， 但 由 于 PHP 在 重 载 方面 并 不 成 熟 ， 在 
这 里 不 再 进行 讨论 。 对 此 感 兴趣 的 读者 可 以 参阅 PHP 手册 ， 或 者 进入 PHP 中 国 论坛 ， 在 
里 面 可 以 找到 一 些 有 关 重 载 方面 的 资料 。 


6.3.$ ”self、parent 与 :: 关 键 字 


在 前 面 的 编程 中 曾 接触 和 到 $this 变量 。 它 出 现在 类 中 ， 具 有 特殊 的 含义 ， 当 一 个 类 被 实 
例 化 后 ，$this 便 指 向 这 个 对 象 ， 可 以 认为 是 对 类 对 象 的 引用 。 

实际 上 在 PHP 中 ， 还 有 self、parent 以 及 :: 〈 双 冒号 )， 它 们 在 面向 对 象 编程 中 都 具有 
特殊 的 用 途 。 

self 指向 类 本 身 ， 也 就 是 self 并 不 是 指向 已 经 实例 化 的 对 象 。self 用 来 引用 类 中 的 静态 
Cstatic) 变量 ， 普 通 变 量 无 法 用 self 引用 。 而 且 self 在 引用 时 后 面 不 用 “->” 而 是 用 双 冒 
号 操作 符 〈::)。 请 看 下 面 的 例子 。 

【 例 6.17】 

<?php 

class myTest{ 

public static $x =10; 

public $y; 

function _ _constructO{ 

S$this->y = self::$x; // 正 确 ， 在 类 中 用 self 加 双 冒 号 引用 静态 变量 
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echo myTest::$x: 
$myObj = new myTestO; 
echo $myObj->y; 

echo myTest::$y; 

echo $myObj->x; 

?> 


本 程序 运行 后 ， 第 9 行 、 第 11 


/正确 ， 用 类 名 加 双 冒 号 引用 静态 变量 
/正确 ， 用 对 象 -> 变量 名 引用 普通 变量 


// 错 误 ， 不 能 用 :: 引 用 普通 变量 
/错误 ， 不 能 用 对 象 -> 访问 静态 变量 


行 输出 10， 第 12 行 和 第 13 行 没 有 任何 输出 〈 报 错 )。 


通过 上 面 的 程序 足以 说 明 self 和 双 冒 号 两 个 特殊 关键 字 的 作用 。 
parent 关键 字 表示 对 父 类 的 引用 。 该 关键 字 一 般 用 在 子 类 中 ， 用 来 调用 父 类 的 构造 函 


数 ， 如 下 面 的 代码 片段 。 
【 例 6.18】 
class Animal{ 


public $name; 


// 父 类 的 构造 函数 


public function _ _construct( $name ){ 


$this->name = $name; 
} 
} 


class Person extends Animal{ 
public $personSex; 


public $personAge; 
// 子 类 的 构造 函数 
function _construct( $personSex, $personAge ) 
{ 
parent:: _construct( " 张 三 " ); // 用 parent 调用 了 父 类 的 构造 函数 


S$this->personSex = $personSex; 
S$this->personAge = $personAge: 


} 


上 面 的 代码 片段 中 ， 首先 定 义 了 一 个 Animal 类 ， 该 类 有 一 个 变量 和 一 个 构造 函数 。 然 
后 定义 了 子 类 Person， 该 类 有 两 个 变量 和 一 个 构造 函数 。 在 创建 Person 类 的 对 象 时 ， 子 类 
中 的 构造 函数 会 覆盖 父 类 中 的 构造 函数 ， 因 此 无 法 直接 给 Sname 变量 赋值 。 这 时 可 以 在 子 
类 的 构造 器 中 调用 parent::。_construct0， 这 样 就 会 执行 父 类 中 的 构造 器 。 这 样 3 个 变量 的 


赋值 语句 便 都 被 执行 了 。 


关于 PHP 中 面向 对 象 的 知识 ， 本 书 就 介绍 到 这 里 。PHP 还 是 一 门 不 断 发 展 的 语言 ， 根 


据 其 发 展 趋势 ， 面 向 对 象 也 将 是 其 如 


EE 点 发 展 目标 。 虽然 目前 PHP 还 不 是 一 门 纯粹 的 面向 对 


象 的 语言 ， 但 是 我 们 相信 ， 随 着 PHP 的 不 断 进 步 ， 其 面向 对 象 特性 也 会 逐步 提高 。 


6.3.6 访问 类 型 


类 型 的 访问 修饰 符 允许 开发 人 员 对 类 成 员 的 访问 进行 限制 ， 这 是 PHP 5 的 新 特性 , 但 、《 / 
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却 是 面向 对 象 编程 语言 的 一 个 好 的 特性 ， 而 且 大 多 数 面向 对 象 编程 语言 都 已 支持 此 特性 。 
PHP 5 支持 如 下 3 种 访问 修饰 符 : public (公有 的 、 默 认 的 ) 、private (私有 的 ) 和 protected 
〈 受 保护 的 ) 。 

1. public 

公有 修饰 符 ， 类 中 的 成 员 没 有 访问 限制 ， 所 有 的 外 部 成 员 都 可 以 访问 ( 读 和 写 ) 该 类 
成 员 ( 包 括 成 员 属 性 和 成 员 方法 )。 在 PHP 5 之 前 的 所 有 版 本 中 ,PHP 中 类 的 成 员 都 是 public， 
而 且 在 PHP 5 中 如 果 类 的 成 员 没 有 指定 成 员 访 问 修饰 符 ， 将 被 视 为 public。 例 如 : 

public $name; 

public function sayO 他; 

2. private 

私有 修改 符 ， 被 定义 为 private 的 成 员 对 于 同一 个 类 里 的 所 有 成 员 是 可 见 的 ， 即 没有 访 
问 限 制 ,但 对 于 该 类 的 外 部 代码 是 不 允许 改变 甚至 读 操作 的 , 该 类 的 子 类 也 不 能 访问 private 
修饰 的 成 员 。 例 如 : 

private $varl = "A'; // 属 性 

private function getValue0O 他 /函数 

3. protected 

保护 成 员 修 饰 符 , 被 修饰 为 protected 的 成 员 不 能 被 该 类 的 外 部 代码 访问 , 但 是 对 于 该 
类 的 子 类 有 访问 权限 ， 可 以 进行 属性 、 方 法 的 读 及 写 操作 ， 该 子 类 的 外 部 代码 包括 其 子 类 
都 不 具有 访问 其 属性 和 方法 的 权限 。 例 如 : 


protected $name; 
protected function sayO€}; 


3 种 修饰 符 的 访问 限制 如 表 6.1 所 示 。 


表 6.1 访问 修饰 符 的 访问 限制 


private protected 


同一 类 中 V 
类 的 子 类 中 
所 有 的 外 部 成 员 

练习 

1. 简 述 封装 性 的 含义 。 

2. 举例 说 明 _set0、_ get 站 、_isset()、 unset(04 个 方法 的 应 用 。 

3. 简 述 覆盖 与 重 载 的 概念 。 

4. PHP 5 中 访问 修饰 符 有 哪些 ? 
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掌握 模块 的 管理 与 实现 
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投票 系统 是 一 般 网 站 常用 的 一 种 系统 。 它 是 一 种 在 网 站 上 提出 调查 题目 ， 由 用 户 在 线 
投票 ， 然 后 对 投票 的 结果 进行 统计 并 直接 显示 的 调查 工具 。 网 站 可 以 通过 投票 系统 统计 的 
数据 来 了 解 用 户 对 一 些 热点 问题 的 看 法 、 对 网 站 的 态度 、 对 网 站 服务 的 评价 或 对 网 站 新 推 
出 产品 或 服务 的 反应 等 ， 从 而 对 网 站 做 出 相应 改进 。 


任务 1 系统 分 大 
任务 描述 
本 任务 通过 系统 背景 、 系 统 模块 分 析 和 系统 流程 图 3 个 方面 来 对 系统 进行 分 析 。 
知识 汇总 


7.1.1 系统 背景 


从 国际 互联 网 到 校园 网 、 企 业 局 域 网 ， 各 种 网 上 投票 系统 随处 可 见 。 问 卷 调 查 、 用 户 
信息 统计 、 经 营 情况 调查 等 都 可 以 作为 投票 的 内 容 。 网 上 投票 系统 凭借 其 方便 、 快 捷 等 特 
点 ， 已 经 成 为 互联 网 资源 中 不 可 缺少 的 一 部 分 。 

网 上 投票 系统 是 网 站 搜集 用 户 需 求 并 有 效 地 实施 市 场 策略 的 重要 手段 之 一 。 通 过 开展 
问卷 调查 ， 可 以 迅速 了 解 不 同行 业 、 不 同 区 域 用 户 的 需求 ， 客 观 地 搜集 需求 信息 ， 及 时 调 
整 网 站 的 营销 策略 以 满足 不 同 的 需求 。 随 着 网 络 技术 的 发 展 ， 网 上 投票 系统 的 作用 将 会 越 
来 越 大 。 


7.1.2 ”系统 模块 分 析 


为 了 更 合理 地 设计 投票 系统 ， 需 要 从 以 下 3 点 进行 分 析 。 

1. 投票 的 形式 

网 上 投票 系统 是 网 站 搜集 用 户 需 求 信息 的 一 个 途径 ， 可 以 根据 网 站 的 需要 设置 一 个 或 
多 个 调查 。 不 同 的 调查 需要 设置 不 同 的 选项 和 调查 要 求 ， 选 项 的 形式 也 是 不 同 的 《〈 单 选 或 
多 选 )， 不 同时 间 段 又 会 有 不 同 的 调查 。 既 然 网 站 要 通过 投票 系统 搜集 信息 ， 那 么 投票 就 必 
须 有 结果 和 对 用 户 信息 的 统计 。 

2. 投票 的 特点 

由 于 互联 网 本 身 的 开放 性 ， 使 网 上 投票 面临 种 种 危险 ， 也 由 此 提出 了 相应 的 安全 控制 
要 求 。 

回 ”信息 保密 性 : 投票 者 有 保密 的 要 求 。 如 果 用 户 名 及 投票 内 容 被 人 获悉 ， 就 对 用 户 

的 隐私 权 构成 了 侵害 。 因 此 网 上 投票 系统 一 般 均 有 匿名 投票 的 要 求 。 
二 回 ”投票 唯一 性 : 一 个 投票 者 其 投票 次 数 应 当 只 有 一 次 。 若 投票 者 可 进行 多 次 投票 ， 
并 
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将 对 调查 内 容 的 可 靠 性 构成 严重 的 威胁 。 

有 了 这 些 特殊 的 要 求 ， 就 需要 对 用 户 的 信息 和 投票 进行 检查 和 处 理 ， 以 保证 投票 的 客 
观 性 和 有 效 性 。 针 对 用 户 信息 ， 如 果 无 特殊 的 要 求 ( 如 只 允许 注册 会 员 参 加 )， 那 么 系统 就 
只 需要 记录 投票 用 户 下、 投票 时 间 和 所 在 区 域 。 投 票 结果 的 显示 也 是 非常 重要 的 ， 一 是 用 
户 希望 自己 的 投票 能 够 及 时 反映 出 来 ; 二 是 用 户 希 望 以 投票 的 结果 作为 参考 。 

3. 投票 系统 结构 


根据 投票 系统 对 形式 的 需求 和 投票 系统 自身 的 特点 ， 需 要 包含 以 下 几 个 模块 。 

回 ”投票 管理 模块 : 该 模块 可 以 添加 、 编 辑 和 删除 调查 选项 ， 设 置 调查 选项 为 多 选 或 
单 选 ， 设 置 调查 的 时 间 期 限 ， 设 置 此 调查 是 否 启用 ， 以 及 统计 显示 调查 结果 。 

回 ”调查 显示 模块 : 该 模块 的 功能 是 显示 已 启用 、 未 过 期 的 调查 。 

回 ”投票 处 理 模块 : 该 模块 需要 对 投票 进行 有 效 性 检查 ， 并 将 投票 结果 和 用 户 信息 写 


入 数据 库 。 
回 ”调查 结果 显示 模块 : 该 模块 主要 是 计算 每 个 调查 选项 统计 结果 的 百分比 并 以 图 表 
的 形式 显示 出 来 。 


回 数据库 操 作 的 基础 模块 : 该 模块 定义 了 连接 数据 库 ， 表 的 查询 ， 数 据 的 插入 、 更 
新 和 删除 操作 。 该 模块 作为 一 个 通用 模块 将 会 在 后 面 的 内 容 用 到 。 


7.1.3 系统 流程 图 
根据 以 上 分 析 ， 开 发 系统 的 流程 如 图 7.1 所 示 。 在 该 流程 中 ， 网 站 管理 员 在 投票 管理 
模块 添加 调查 数据 ， 然 后 在 调查 显示 模块 显示 出 来 。 用 户 通过 调查 显示 的 “投票 ”按钮 投 


票 ， 数 据 被 传递 到 投票 处 理 模块 ， 处 理 之 后 转 到 调查 结果 显示 页 面 。 用 户 也 可 以 通过 调查 
显示 模块 的 “查看 结果 ”按钮 直接 转 到 调查 结果 显示 页 面 。 


图 7.1 系统 流程 图 


xu if 
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任务 2 数 扰 库 的 建立 与 攻 作 


任务 描述 
建立 数据 库 文件 并 进行 相应 的 操作 。 
知识 汇总 


7.2.1 数据 库 的 建立 

通过 上 面 对 投 票 系统 功能 的 分 析 可 知 ， 需 要 存储 的 信息 有 调查 信息 、 调 查 选项 信息 和 
用 户 信 息 。 因 此 ， 本 系统 需要 建立 调查 信息 表 、 调 查 选 项 信息 表 和 用 户 信息 表 。 这 几 个 表 
之 间 的 关系 如 图 7.2 所 示 。 

从 图 7.2 可 以 看 出 ， 调 查 信 息 、 调 查 选项 信息 和 用 户 信 息 都 是 一 对 多 的 关系 ， 并 通过 
调查 信息 ID 关联 。 构架 的 投票 系统 数据 库 vote (采用 MySQL 数据 库 ) 如 表 7.1 一 7.3 所 示 。 


调查 信息 表 调查 选项 信息 表 
EE VOTE INFO : EE ITEM _ INFO 
F_ID 表 ID F_ID 表 ID 
器 F ID VOTE INFO 调查 信息 表 ID 
1:N 
用 户 信息 表 
EE VOTE USER 
F_ID 表 ID 
F_ID_ VOTE INFO 调查 信息 表 ID 


图 7.2 数据 表 关 系 图 


表 7.1 调查 信息 表 : EM_VOTE_INFO (用 于 存储 调查 内 容 ) 


字段 名 类 型 (长度) 备注 
F ID INTUO) 自动 增加 
F VOTE _ TITLE VARCHAR(255 
F VOTE _ START INT(10)TIMESTAMP 
F VOTE END INT(10)TIMESTAMP | 调查 结束 时 间 | 否 


1 为 单 选 默认 ) 


F_VOTE IIEM_TYPE |TINYINT i 
人 2 为 多 先 


1 为 启用 (默认 》 
0 为 禁用 


FE VOTE IS DISPLAY |TINYINT 
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表 7.2 调查 选项 信息 表 : EE_ITEM_INFO (用 于 存储 调查 的 选项 信息 ) 


F ITEM COUNT 


F ITEM ORDER 


FID 


FID 


7.2 


配置 


F USER IP 


F USER AREA 


.2 ”数据库 操作 基础 模块 


VOTE _ INFO 


am 一 ss 
用户 所 在 区 域 | 吾 | 再 | | 


数据 库 操作 基础 模块 主要 实现 数据 库 连 接 以 及 对 数据 库 表 的 一 些 基本 操作 功能 ， 包 括 
文件 和 数据 库 操 作文 件 。 下 面 分 别 进行 详细 讲解 。 

1. 配置 文件 config.inc.php 

建立 配置 文件 是 系统 构架 需要 考虑 的 重点 。 因 为 在 一 个 系统 里 会 有 一 些 常用 的 参数 在 


人 多 地 方 可 以 用 到 ， 如 果 到 使 用 时 才 定 义 ， 那 么 需要 修改 的 时 候 就 会 相当 麻烦 ， 而 且 容 易 
出 错 ， 代 码 的 可 读 性 也 很 差 。 配 置 文件 中 主要 是 数据 库 连 接 用 的 参数 和 一 些 全 局 变量 。 代 
码 如 下 : 

<2php 

define("UserName", "root"): /数据 库 连 接 用 户 名 

define("PassWord", "root"): /数据 库 连 接 密 码 

define("ServerName", "localhost"); // 数 据 库 服 务 器 的 名 称 

define("DBName","Languagevote"); // 数 据 库 名 称 

define("ERRFILE","err.php"); // 错 误 处 理 显 示 文 件 

define(ROOT_PATH,', dirmame( FILE ).'/"): // 定 义 根 目 录 路 径 

define(INCLUDE, PATH', ROOT PATH . 'include/"): // 定 义 包含 文件 目录 路 径 

?> 

2， 数据库 操作 文件 db.inc.php 

PHP 是 一 种 支持 面向 对 象 的 编程 的 语言 ， 数 据 操作 文件 主要 用 于 建立 一 个 类 ， 该 类 的 
初始 化 构造 函数 可 以 连接 数据 库 和 表 。 其 他 的 方法 包括 对 表 的 查询 ， 数 据 的 插入 、 更 新 、 
删除 操作 和 事务 处 理 。 事 务 处 理 是 在 执行 多 个 更 新 或 删除 操作 时 为 了 保证 数据 完整 性 而 使 

的 。 把 这 些 基本 操作 封装 在 一 个 模块 里 ， 对 于 代码 的 可 读 性 、 系 统 的 扩展 性 和 健壮 性 都 

有 好 处 。 代 码 如 下 : 


\ 
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<?php 
/** 
* 功能 : 数据库 的 基础 操作 类 
yy 
class DBSQL{ 
private $CO) 
ed 
* 功能 : 初始 化 构造 函数 ， 连 接 数 据 库 
be 
public function _constructO{ 
ty 


投票 系统 开发 (PHP+MySQL ) 国 


/定义 数据 库 连接 变量 


/捕获 连接 错误 并 显示 错误 文件 


$conn = mysql connect(ServerName,UserName,PassWord):; 


}catch (Exception $e) 
{ 
$msg = $e; 
include(ERRFILE); 
} 
ty { 
mysql_select_db(DBName,$conn); 
}catch (Exception $e) 
{ 
$msg = $e; 
include(ERRFILE): 
; 
S$this->CONN = $conn:; 
} 
/冰冰 
* 功能 : 数据库 查询 函数 
* 参数 :$sql SQL 语句 
* 返回 : 二 维 数组 或 FALSE 
对 
public function select($sql = ""){ 


// 捕 获 数据 库 选择 错误 并 显示 错误 文件 


if (empty($sql)) return false; // 如 果 SQL 语句 为 空 则 返回 FALSE 

if (empty($this->CONN)) return false; // 如 果 连 接 为 空 则 返回 FALSE 

try{ /捕获 数据 库 选 择 错误 并 显示 错误 文件 
$results = mysql_query($sql,$this->CONN): 

}catch (Exception $e){ 
$msg = $e; 
include(ERRFILE): 

} 


if((!$results) or (empty($results))) { 
@mysql_free_result($results); 
Tetum false: 

} 


$count = 0: 
$data = array0: 


while ($row = @mysql fetch array($results)) { /把 查询 结果 本 


/如 果 查 询 结果 为 空 则 释放 结果 并 返回 


FALSE 


EE 组 成 一 个 二 维 数组 


yy 


$data[$count] = $row: 
$count+t+; 


@mysql free result($results); 


return $data: 
} 
机 
* 功能 : 数据 插入 函数 
* 参数 : $sql SQL 语句 
* 返回 : 0 或 新 插入 数据 的 ID 


如 
public function insert($sql = ""){ 
if (empty($sql)) return 0; // 如 果 SQL 语句 为 空 则 返回 FALSE 
站 (empty($this->CONN)) return false; /如 果 连 接 为 空 则 返回 FALSE 
try{ /捕获 数据 库 选择 错误 并 显示 错误 文件 
$results = mysql_query($sql,$this->CONN): 
}catch(Exception $e){ 
$msg = $e; 
include(ERRFILE); 
} 
if (!$results) /如 果 插 入 失败 就 返回 0, 否则 返回 当前 插入 数据 人 D 
return 0; 
else 
Teturn mysql_insert_id($this->CONN):; 
} 
/* * 


* 功能 : 数据 更 新 函数 
* 参数 : $sql SQL 语句 
* 返回 : TRUE OR FALSE 


Wy 
public function update($sql = ""){ 
这 empty($sqD) return false; // 如 果 SQL 语句 为 空 则 返回 FALSE 
if(empty($this->CONN)) retum false; /如 果 连 接 为 空 则 返回 FALSE 
try{ /捕获 数据 库 选 择 错误 并 显示 错误 文件 
$result = mysql query($sql$this->CONN): 
}catch(Exception $e){ 
$msg = $e; 
include(ERRFILE): 
} 
Tetum $result; 
} 
/ 六 六 


* 功能 : 数据 删除 函数 

* 参数 : $sql SQL 语句 

* 返回 : TRUE OR FALSE 
机 


所 lf 
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public function delete($sql = ""){ 
if(empty($sq]l)) return false; // 如 果 SQL 语句 为 空 则 返回 FALSE 
这 empty($this->CONN)) retum false; // 如 果 连 接 为 空 则 返回 FALSE 
ty{ 
$result = mysql_query($sql.$this->CONN); 
}catch(Exception $e){ 
$msg = $e; 
include(ERRFILE): 
} 


Tetum $result; 


} 
sind 
* 功能 : 定义 事务 
ed 
public function begintransaction() 
{ 
mysql query("SET AUTOCOMMIT=0"); // 设 置 为 不 自动 提交 ,因为 MySQL 默认 立即 执行 
mysql_query("BEGIN"); /开始 事务 定义 
} 
/** 
* 功能 : 回 滚 
好 
public function rollbackO 
{ 
mysql_query("ROOLBACK"):; 
} 
/于 * 
* 功能 : 提交 执行 
yy 
public function commitO 
{ 
mysql_query("COMMIT"): 
} 


任 分 3 措 块 管理 


任务 描述 


投票 管理 模块 
调查 显示 模块 
投票 处 理 模块 
调查 结果 显示 模块 


同 加 网 名 


\y/ 
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知识 汇总 
7.3.1 投票 管理 模块 


票 管理 模块 用 于 实现 网 站 管理 员 对 投票 数据 的 管理 ， 可 以 添加 、 编 辑 、 删 除 调查 选 

项 ， 还 可 以 查看 调查 统计 的 信息 。 该 模块 包括 调查 类 文件 、 调 查 列表 文件 、 添 加 调查 文件 、 

编辑 调查 文件 、 删 除 调查 文件 、 用 户 统计 文件 以 及 添加 和 编辑 调查 选项 文件 、 选 项 顺序 设 

置 文件 、 删 除 调查 选项 文件 、 用 户 统 计 信 息 列表 文件 、 区 域 统计 文件 。 下 面 分 别 进行 讲解 。 
1. 调查 类 文件 vote.inc.php 


该 文件 是 一 个 类 文件 ， 其 功能 主要 是 对 调查 信息 、 调 查 选项 信息 和 用 户 信息 的 操作 ， 
除 一 些 基本 操作 外 ， 在 开发 的 过 程 中 还 可 以 根据 需要 添加 其 他 操作 。 调 查 类 文件 作为 一 个 
包含 文件 被 调用 。 代 码 如 下 : 


<?php 

require_once(INCLUDE PATH . "dbinc.php); 

class Vote extends DBSQL 

{ 
public $_name ='EM_VOTE INFO': // 定 义 调查 表 名 称 变 量 
public $_item ="'EE ITEM_INFO': // 定 义 调查 选项 表 名 称 变量 
public $_user ='EE VOTE_USER'; /定义 用 户 信息 表 名 称 变量 
public $_pagesize = 10; /定义 每 页 提取 记录 数 
public $_type = array("1"=>" 单 选 ","2"=>" 多 选 "); // 定 义 选项 类 型 


public $_display = array("0"=>" 禁 用 ","1"=>" 启 用 "); /定义 调查 启用 显示 
private function _constructO 
{ 
parent::_construct(); 
} 
/** 
* 功能 : 提取 调查 列表 
* 返回 : 数组 
yy 
public function getVoteListO{ 
$sql = "SELECT * FROM " . $this->_name; 
Tetum $this->select($sq]); 
} 
/站 来 
* 功能 : 提取 指定 表 的 指定 ID 的 记录 
* 参数 : $id 表 ID，$name 表 名 称 
* 返回 : 数组 
时 
public function getInfo($id,$name) 
{ 
$sql = "SELECT * FROM" .$name ." WHEREF ID= $id"; 
S$r = $this->select($sql); 
retum $r[0]; 


人 
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} 

ms 
* 功能 : 向 指定 表 中 插入 数据 
* 参数 : $name 表 名 称 ，$data 数组 (格式 : $data[' 字 段 名 ] = 值 ) 
* 返回 : 插入 记录 了 DD 


”Y 
public function insertData($name,$data) 
{ 
$field = implode(',',array_keys($data)):; // 定 义 SQL 语句 的 字段 部 分 
foreach($data as $key => $val) // 组 合 SQL 语句 的 值 部 分 
{ 
$value ="". $val . ""; 
if($key < count($data) - 1) // 判 断 是 否 到 数组 的 最 后 一 个 值 
S$value = ","; 
} 


$sql = "INSERT INTO " . $name . "(" . $field .") VALUES(" . $value . ")"; 
Tetum $this->insert($sq]); 
} 
/** 
* 功能 : 更 新 指定 表 指 定 ID 的 调查 表 记 录 
* 参数 : $name 表 名 称 ，$id 表 ID，$data 数组 (格式: $data[' 字 段 名 '] = 值 ) 
* 返回 : TRUE OR FALSE 
public function updateData($name,$id,$data){ 
$col = arrayO; 
foreach ($data as $key => $value) 


$col[] = $key . "=" . $value .™™"; 
} 
$sql = "UPDATE " .$name ." SET " .implode(',',$col) ." WHEREF ID = $id"; 
Teturn $this->update($sql); 
} 
/** 
* 功能 : 删除 指定 ID 的 调查 表 记 录 及 相关 表 记 录 
* 参数 : $id 调查 表 ID 
* 返回 : TRUE OR FALSE 
,yy 
public function delData($id){ 
S$this->begintransaction(); 


try{ 
$sql = "DELETE FROM " . $this-> item ." WHEREF ID VOTE INFO=". $id; 
$this->delete($sql): /删除 调查 选项 里 面 的 相关 数据 
$sql = "DELEIE FROM " . $this-> user . " WHEREF ID VOTE INFO =" .9$id: 
S$this->delete($sq]l):; /删除 用 户 统计 表 里 面 的 相关 数据 


$sql = "DELETE FROM " . $this-> name ." WHEREF ID =" .9$id: 
S$this->delete($sql); 


}catch(Exception $e){ 
S$this->rollback(; 
Tetum false: 
\V v } 
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S$this->commit(); 
return true; 


} 
ns 
* 功能 : 提取 指定 调查 ID 的 选项 
* 人 参数: $vote id 调查 ID 
* 返回 : 数组 
bd 
public function getItemList($vote id) 
{ 


$sql = "SELECT* FROM " . $this-> item ." WHEREF ID VOTE INFO = $vote id"; 
return $this->select($sq)); 
} 
/** 
* 功能 : 删除 指定 ID 的 选项 表 记 录 
* 参数 : $id 表 了 D 
* 返回 : TRUE OR FALSE 
eh 
public function delItemData($id) 
{ 
$sql = "DELETE FROM " . $this-> item ." WHEREF_ID = $id"; 
return $this->delete($sq]); 
$sql .= "ORDER BY F_ITEM_ORDER"} 
/于 * 
* 功能 : 提取 指定 调查 ID 的 用 户 统计 信息 
* 参数 : $vote id 调查 ID，$page 当前 页 码 
* 返回 : 数组 
public function getUserList($vote_id,$page=1) 
{ 
$start = ($page - 1) * $this-> pagesize; 
$sql ="SELECT * FROM " . $this-> user ." WHEREF ID VOTE INFO = $vote id"; 
$sql .= " LIMIT $start,$this-> pagesize": 
Tetum $this->select($sq)); 
} 
1 
* 功能 : 提取 指定 调查 ID 用 户 统计 记录 的 条 数 
* 参数 : $vote id 调查 ID 
* 返回 : 记录 条 数 
可 
public function getUserCount($vote id) 
{ 
$sql="SELECT COUNT(E ID) FROM". $this-> user." WHEREF ID VOTE INFO= $vote id" 
S$r = $this->select($sql); 
Tetum $r[0]J[0]; 
} 
/** 
* 功能 : 删除 指定 D 的 用 户 统计 记录 
* 参数 : $id 用 户 统计 表 ID 
* 返回 : TRUE OR FALSE 
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yy 
public function delUserData($id) 
{ 
$sql ="DELETE FROM " . $this-> user ." WHEREF ID= $id"; 
return $this->delete($sq]); 


} 


?> 


对 单个 表 进 行 查询 、 插 入 、 更 新 和 删除 时 的 代码 很 相似 ， 唯 一 不 同 的 是 操作 表 的 名 称 。 
这 里 可 以 把 这 些 对 单个 表 的 基本 操作 放 到 基础 类 文件 db.inc.php 里 面 。 代 码 如 下 : 


/下 * 
* 功能 : 提取 指定 表 的 指定 ZD 的 记录 
* 参数 : $id 表 ID，$name 表 名 称 
* 返回 : 数组 
~ 
public function getInfo($id,$name) 
$sql = "SELECT * FROM " . $name ." WHEREF_ID = $id"; 
S$r = $this->select($sql); 
return $r[0]: 
} 
me 
* 功能 : 向 指定 表 中 插入 数据 
* 参数 : $name 表 名 称 ，$data 数组 (格式 : $data[' 字 段 名 ']= 值 》 
* 返回 : 插入 记录 JD 


yp 
public function insertData($name,$data) 
{ 
$field = implode(',,array_keys($data)); /定义 SQL 语句 的 字段 部 分 
$i=0; 
foreach($data as $key => $val) // 组 合 SQL 语句 的 值 部 分 
S$value ="". $val . ""; 
if($i < count($data) - 1) // 判 断 是 否 到 数组 的 最 后 一 个 值 
$value =","; 
$itt; 
} 
$sql = "INSERT INTO " . $name . "(" . $field .") VALUES(" . $value . ")"; 
return $this->insert($sql); 
} 
/来 


* 功能 : 更 新 指定 表 指定 卫 的 调查 表 记 录 
* 参数 : $name 表 名 称 ，$id 表 ID，$data 数组 〈 格 式 : $data[' 字 段 名 '] = 值 ) 
* 返回 : TRUE OR FALSE 
oy 
public function updateData($name,$id,$data){ 
$col = arrayO; 
yy foreach ($data as $key => $value) 
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$col[] = $key . "=" . $value . "": 


} 
$sql = "UPDATE " . $name ." SET " .implode(',',$col) ." WHEREEF ID = $id"; 
return $this->update($sq]); 


} 


/** 

* 功能 : 删除 指定 ID 的 表 记 录 

* 参数 : $id 表 ID，$name 表 名 称 
* 返回 : TRUE OR FALSE 


public function delData($id, $name) 
{ 


$sql ="DELETE FROM " . $name ." WHEREF_ID= $id"; 


Teturn $this->delete($sql); 
} 


2. 调查 列表 文件 VoteList.php 


该 文件 的 功能 是 显示 调查 信息 表 中 的 数据 列表 。 该 文件 包含 调查 类 文件 。 提 取 列 表 的 
数据 是 通过 调查 类 文件 里 面 的 提取 列表 方法 来 实现 的 。 首 先 声 明 一 个 调查 类 Vote 的 对 象 ， 
通过 该 对 象 来 调用 类 的 提取 列表 方法 getVoteList0。 通 过 调查 列表 页 面 可 以 链接 到 添加 、 编 


辑 、 选 项 管理 、 用 户 统计 及 删除 操作 页 面 。 调 查 列表 界面 如 图 7.3 所 示 。 


20051C01 2005-10-20 利 这 未 过 则 斋 针 | 渤 项 各 理 | i 的 

你 对 同上 上 志 基调 本 了 20081001 20081620 过 #9 胡可 受 入 | 呈 户 入 计 信息] 由 了] 

在职 本 网 站 网站 的 计 怪 人 2005100t 200510.20 六 4 。。 户 朋 ETTOTTTTT 

20001C01 2005-1020 音 这 来 过 则 茜 周 元 旨 | I 项 管理 | 息 户 经 计 信息 ] 遇险 ) 

雹 所属 行业 人 2005.0801 2005.0620 和 BN 所 用 明 由 受 下 入 和 | 天 户 村 计 信息 ] 节 辽 ) 

人 的 外 同人 2005-00.04 2005-00-20 3 由 疡 则 ETITTTTTTTT 
生 加 司 查 


图 7.3 调查 列表 
代码 如 下 : 


<?php 

require_once("config.inc.php"); 

require_once(INCLUDE_PATH . vote.inc.php): 

$vote = new Vote(); // 声 明 一 个 对 象 $vote 
S$list = $vote->getVoteList(); 

$time = time(); 

?> 

<form name="forml1" action="" method="post"> 


<table width="98%" border="0" align="center" cellspacing="0" class="] table_ 1" id="table_ 1"> 


<tr class="title"> 
<td width="5%"> 序 号 </td> 
<td width="24%"> 调 查 标题 </td> 
<td width="14%"> 开 始 时 间 </td> 
<td width="12%"> 结 束 时 间 </td> 
<td width="12%"> 选 项 类 型 </td> 


\ 


‘1 
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<td width="6%"> 是 否 过 期 </td> 
<td width="6%"> 是 否 启 用 </td> 
<td width="21%"> 操 作 </td> 
</tr> 
<?php 
if($list) /如 果 有 记录 则 循环 显示 
{ 


foreach($list as $key 一 $value) 
{ 
> 
<tr class="] field"> 
<td align="left"><?php echo ($key + 1)?></td> 
<td align="left"><?php echo $value['F_VOTE TITLE']?></td> 
<td align="left"><?php echo date('Y-m-d',$value['F_VOTE START])?></td> 
<td align="left"><?php echo date(Y-m-d,$value[F_ VOTE END'"])?></td> 
<td align="left"><?php echo $vote-> type[$value['F_VOTE ITEM _TYPE']]?></td> 
<td align="left"><?php if($value['F_VOTE_END'] > $time) echo "未 过 期 ":else echo "已 过 期 ":?></td> 
<td align="left"><?php echo $vote->_display[$value['F_VOTE JIS_DISPLAY"]]?></td> 
<td align="left"><a href="EditVote.php?id=<?php echo $value[F_ID']?>">[ 编 辑 ]</a> 
<a href= "TtemList.php?id=<?php echo $value[F_ID']?>">[ 选 项 管理 ]</a> 
<a href="UserList.php?id=<?php echo $value[F_ID']?>">[ 用 户 统计 信息 ]</a> 
<a href="DelVote.php?id=<?php echo $value[F ID']?>">[ 删 除 ]</a> </td> 
</tr> 
<2php 


<tr> 
<td colspan="13" align="center"><input type="submit" name="Submit3" value=" 添加 调查 " 
onclick= "javascript:window.location='AddVote.php" /></td> 
</tr> 
</table> 
</form> 


3. 添加 调查 文件 AddVote.php 
该 文件 的 功能 是 添加 新 调查 ， 将 数据 写 入 调查 信息 表 中 。 该 文件 由 图 7.3 中 调查 列表 
页 面 的 “添加 调查 ”按钮 连接 过 来 。 用 户 填 写 完 表单 后 单 击 “ 提 交 ” 按 钮 进行 处 理 。 表 单 
提交 给 自身 ， 通 过 判断 是 否 为 提交 操作 进行 数据 处 理 。 数 据 的 处 理 通 过 调查 类 Vote 的 对 象 
调用 父 类 DBSQL 的 insertData() 方 法 实现 。 添 加 调查 界面 如 图 7.4 所 示 。 
i 


讽 可 怪 题 ;您 对 同 站 车) 焉 宣 程 裤 ? 
所 必 兴 堪 : 单 选 一 
FA: 2006 证 [ID 0 .7B 
ss 2006 同和 10 月 07 [| 
是 否 启 用 : <: 所 用 
= | 
图 7.4 添加 调查 
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(1) 主 程序 部 分 。 
该 部 分 代码 用 于 实现 提交 数据 的 处 理 和 操作 界面 的 显示 。 代 码 如 下 : 


<?php 

require_once('../config.inc.php"); 

require_once(INCLUDE PATH . vote.incphp); 

$vote = new Vote(); 

list($year, $month,$day) = explode("-",date('Y-m-d")); 

这 $_SERVER[REQUEST METHOD'] — 'POST') // 判 断 是 否 为 提交 请 求 ， 若 是 则 添加 数据 
{ 


$data[l'F_VOTE TITLE'] = $_POST['title]: 

$data['F_VOTE_START'] = mktime(0,0,0,$ POST['start_m'],$ POST['start_d'],$_POST['start_y"]); 
$data['F_VOTE_END'] = mktime(0,0,0,$ POST['end_m'].$ POST['end d'"],$ POST['end y']): 
$data[F_ VOTE ITEM_TYPE]= $_POST[type]: 

$data['F_VOTE IS_DISPLAY']= $_POST['display']: 


if($vote->insertData($vote-> name,$data)) 1/ 判断 是 否 操 作成 功 
echo "操作 成 功 "; 
else 
echo "操作 失败 "; 
echo "<a href="VoteList.php 人 > 返回 </a>"; 
exit(); 
} 
?> 


<script language="javascript" sre="../js/date.js"></script> 
<form name="forml1" action="" method="post" onsubmit="javascript:return checkO:"> 
<table width="60%" border="0" align="center" cellpadding="0" cellspacing="0" class="] table"> 
<tr class="title"> 
<td colspan="2" align="left">&nbsp:</td> 
</t> 
<tr class="] field"> 
<td align="right"> 调 查 标题 ，</td> 
<td><input name="title" type="text" id="title" size="40" /></td> 
</tr> 
<tr class="] field"> 
<td align="right"> 所 属 类 型 : </td> 
<td><select name="type" id="type"> 
<?php 
foreach ($vote-> type as $key => $value) /循环 显示 类 型 选择 下 拉 列 表 框 
echo "<option value=$key>$value</option>"; 


} 


和 


</select> </td> 
</tr> 
<tr class="] field"> 
<td width="24%" align="right"> 开 始 时 间 : </td> 
<td width="76%"> 
<select name="start_y" id="start y"> 


<?php 


for($i=1;$1<=($year+1):$i++) 
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/循环 显示 开始 年 份 下拉 列 表 框 


/设置 默认 选项 


<select name="start_m" id="start_m" onchange="javascript:register_buildDay(this.value);"> 


{ 
echo "<option value=$i": 
if($i— $year) 
echo " selected='selected"™": 
echo ">$1</option>"; 
} 
?> 
</select> 
年 
<?php 
for($i=1;$i<=12;$i++) 
{ 
if($i< 10) 
$i="0"'. $i; 
echo "<option value=$i"; 
if($i =— $month) 
echo " selected='selected"™"; 
echo ">$i</option>"; 
上 
</select> 
月 
<select name="start_d" id="start_d"> 
<2php 


echo "<option value='$day'’>$day</option>"; 
?> 
</select> 
日 </td> 
</tr> 
<tr class="] field"> 
<td align="right"> 结 束 时 间 : </td> 
<td> 
<select name="end y" id="end y"> 
<2php 
for($i=1:$i<=($year+l1):$i++) 
{ 
echo "<option value=$i"; 
if($i 一 $year) 
echo " selected='selected"; 
echo ">$1</option>"; 
} 
性 
</select> 
年 


<select name="end_m" id="end_m" onchange="j 


<?php 
for($i=1:$i<=12:$i++) 


/循环 显示 开始 月 份 下 拉 列 表 框 


/设置 默认 选项 


// 列 表 


/循环 显示 结束 年 份 下 拉 列 表 杠 


/设置 默认 选项 


avascript:register_buildDay(this.value):"> 


/循环 显示 结束 月 份 下 拉 列 表 框 
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if($i < 10) 
$i="0"'. $i; 
echo "<option value=$i"; 
if($i 一 $month) // 设 置 默 认 选 项 
echo " selected='selected"™":; 
echo ">$i</option>"; 
} 
?> 
</select> 
月 
<select name="end_d" id="end d"> 
<2php 
echo "<option value='$day'>$day</option>"; 
?> 
</select> 
日 </td> 
</tr> 
<tr class="] field"> 
<td align="right"> 是 否 启 用 : </td> 
<td><input name="display" type="radio" value="1" checked="checked" /> 
启用 
<input type="radio" name="display" value="0" /> 
禁用 </td> 
</tr> 
<tr class="title"> 
<td colspan="2" align="center"><input type="submit" name="Submit" value=" 提 交 " /> 
&nbsp; 
<input type="reset" name="reset" value=" 重 置 " /></td> 
</t> 
</table> 
<table align="center" border="0" cellpadding="0" cellspacing="0" width="98%"> 
<tbody><tr> 
<td>&nbsp;</td> 
</tr> 
</tbody></table> 
</form> 


(2) 客户 端 程序 JavaScript)。 

在 主 程序 代码 里 ， 表 单 提 交 之 前 会 用 到 客户 端 语言 JavaScript 来 实现 日 期 的 选择 和 数 
据 正 确 性 、 完 整 性 检查 。 数 据 正确 性 、 完 整 性 检查 是 在 添加 和 编辑 数据 页 时 必需 的 。 必 须 
检查 那些 在 数据 库 里 面 不 能 为 空 的 字段 和 有 特殊 格式 的 字段 , 保证 它们 的 正确 性 和 完整 性 。 
调用 JavaScript 是 通过 表单 中 的 onsubmit="javascript:return check0:" 实 现 的 。 该 调用 的 意思 
是 ， 如 果 返 回 TRUE， 就 提交 表单 ;否则 不 提交 。checkO 函 数 的 代码 如 下 : 


<script language="javascript"> 
/功能 : 检查 日 期 格式 是 否 是 有 效 格式 
function checkIsValidDate(str) 


\ 


/ 


} 
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if(str —"") /如果 参数 为 室 ， 则 返回 FALSE 
Tetum false; 
var arrDate = str.split("-"); // 把 参数 用 split0 函 数 分 割 成 数组 ， 它 等 同 于 PHP 中 的 
explode() 函 数 
if(parseInt(arrDate[0].10) < 100) // 如 果 年 份 小 于 100， 则 表示 是 21 世纪 


arrDate[0] = 2000 + parseInt(arrDate[0],10) + ""; 
var date = new Date(arrDate[0],(parseInt(arrDate[1],10) -1)+"",arrDate[2]); /格式 化 为 日 期 格式 
这 date.getYear0 — arrDate[0] /判断 格式 化 后 日 期 的 年 、 月 、 日 是 否 和 参数 的 相等 ， 相 等 
则 是 有 效 格式 
&& date.getMonth() 一 (parseInt(arrDate[1],10) -1)+"" 
&& date.getDate() 一 arrDate[2]) 
Tetum true; 
else 
return false; 


/功能 : 检查 开始 日 期 是 否 小 于 结束 日 期 
/参数 :strStart 开始 日 期 ，strEnd 结束 日 期 
function checkDateEarlier(strStart,strEnd) 


{ 


if(checkIsValidDate(strStart) 一 false || checkIsValidDate(strEnd) 一 false) 


retum false; /检查 日 期 格式 是 否 有 效 
if((strStart 一 "" ) 用 (stEnd 一 "") /检查 日 期 是 否 为 空 
return false; 


Var aIT1 = strStart.split(™-"); 
Var arr2 = strEnd.split("-"); 
var datel = new Date(arr1[0],parseInt(arrl[1].replace(/^0/,""),10) - 1,arr1[2)):; 
Var date2 = new Date(arr2[0],parseInt(arr2[1].replace(/^0/,""),10) - Larr2[2]); 


if(arl[1].length — 1) // 将 月 份 格式 化 为 00 这 种 形式 
arrl[1] = "0" + arrl[1]; 

if(arrl[2].length 一 1) /将 日 格式 化 为 00 这 种 形式 
arrl[2] = "0" + arrl[2]; 

if(arr2[1].length 一 1) // 将 月 份 格式 化 为 00 这 种 形式 
arr2[1] = "0" + am2[1]: 

if(arr2[2].length — 1) // 将 日 格式 化 为 00 这 种 形式 


arr2[2]="0" + arr2[2]; 
var dl = arrl[0] + arrl[1] + arrl[2]: // 将 开始 日 期 组 合成 一 个 字符 串 
var d2 = arr2[0] + arr2[1] + arr2[2]: // 将 结束 日 期 组 合成 一 个 字符 串 
if(parseInt(d1,10) > parseInt(d2,10)) /将 两 个 字符 串 转 化 成 整数 ， 如 果 dl>d2 则 开始 日 期 大 于 


结束 日 期 
Tetum false; 
else 
Tetum true; 
} 
// 定 义 一 个 javascript 的 原形 
String.prototype.len = functionO{ /计算 字符 串 的 长 度 〈 一 个 双 字 节 字 符 长 度 计 2，ASCI 
字符 计 1) 


} 


return this.replace(/[^\x00-\xff]/g,"aa").length: 
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function check() 


var Start = document.form!].start_y.value + "-" + documentforml.start_ m.value + "-" + document. 
forml.start_d.value; 

var End = document.forml.end y.value + "-" + document.forml.end_m.value + "-" + document. 
forml.end d.value; 


if(document.form! .title.value — ") /判断 标题 是 否 为 室 ， 为 空 则 返回 FALSE 
€ 
alert(' 请 填写 调查 名 称 ); 


document.forml .title.focus(); 


Tetum false; 
} 
这 document fommltitle value len0 > 100) // 判 断 标题 长 度 是 否 超过 100 
{ 
alert( 调 查 标题 不 能 超过 100 个 字 ') 
document.forml .title.focus(); 
Tetum false; 
} 
if(!checkDateEarlier(Start,End)) // 判 断 开始 日 期 是 否 大 于 结束 日 期 
{ 
alert(' 开 始 日 期 因 不 能 小 于 结束 日 期 '); 
Tetum false; 
} 
</script> 


日 期 处 理 JavaScript 文件 datejs 的 代码 如 下 : 


// 功 能 ， 显示 开始 日 期 指定 月 份 的 天 数 
/参数 : month 月 份 
function register_buildDay(month) 


{ 
Var yearOb=document.getElementById('start_y"); // 取 得 开始 日 期 年 份 
var dayOb=document.getElementById('start_d"): // 取 得 开始 日 期 天 数 
document.getElementById('start_d').length = 0; 
var lastDay=register_getDay(yearOb.value,Number(month)); 。 // 取 得 当月 的 天 数 
for(var i=1;i<=lastDay;i++) /循环 输 出 下 拉 列 表 框 
{ 
Var dayOption=document.createElement("OPTION"): 
dayOb.options.add(dayOption); 
dayOption.innerText=1; 
dayOption.value=i; 
dayOb.selectedIndex=0; 
} 
} 
/功能 : 重新 设置 开始 日 期 的 天 数 


function register_resetDay(O) 
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var dayObject=documentgetElementById(start_d): 
var dayLength=dayObject.length; 


for(var i=1:;i<dayLength:dayLength--) // 将 开始 日 期 天 数 的 下 拉 列 表 框 循环 移出 
{ 
dayObject.remove(?); 
} 
} 
// 功 能: 显示 结束 日 期 指定 月 份 的 天 数 
/参数 : month 月 份 
function register_buildEndDay(month) 
{ 
var yearOb=document.getElementBylId('end y"); ”// 取 得 结束 日 期 的 年 份 
Var dayOb=document.getElementById('‘end_d'"); // 取 得 结束 日 期 的 天 数 


document.getElementById('end_d').length = 0; 
var lastDay=register_getDay(yearOb.value,Number(month)); /取得 当月 的 天 数 
for(var i=1:i<=lastDay:i++) /循环 输出 下 拉 列 表 框 
{ 
var dayOption=document.createElement("OPTION"): 
dayOb.options.add(dayOption); 
dayOption.innerTex 人 1 
dayOption.value=i; 
dayOb.selectedIndex=0; 
} 
} 
/功能 : 重新 设置 结束 日 期 天 数 
function register_resetEndDay() 


{ 
var dayObject=document.getElementById('end_d'): 
var dayLength=dayObject.length; 
for(var i=1;i<dayLength:dayLength--) // 将 结束 日 期 天 数 的 下 拉 列 表 框 循环 移出 
{ 
dayObject.remove(i); 
} 
} 


/功能 : 取得 指定 年 份 和 月 份 的 天 数 

// 参 数 ，Year 年 份 Month 月 份 

function register_getDay(YearMonth) 

{ 
var LastDay = 0; 
switch (Month) ”// 判 断 月 份 :， 1，3，5，7，8，10，12 月 的 天 数 为 31 天 ; 4，6，9，11 月 为 30 天 
{ 


case 1: 
Case 3: 
Case 5: 
Case 7: 
Case 8: 


Month="0"+ Month: 
case 10: 
case 12: 
LastDay=31; 
break: 
case 4: 
case 6: 
case 9: 
Month="0"+ Month; 
case 11: 
LastDay=30; 
break:; 
case 2: /判断 是 否 为 六 年 ， 是 则 2 月 为 29 天 ， 不 是 则 为 28 天 
Month="0"+ Month; 
if ((Year%4—0&&Year%100!=0)|[Year%400=—0) 
人 
LastDay=29; 
else 
€ 
LastDay=28; 


break: 
default: 
LastDay=0; 


} 


return LastDay:; 
} 


4. 编辑 调查 文件 EditVote.php 

该 文件 的 功能 是 编辑 调查 信息 。 该 文件 由 调查 列表 页 面 “ 操 作 ” 列 的 “[ 编 辑 ]” 超 链 
接连 接 过 来 传递 调查 ID 参数 。 用 户 编 辑 表单 数据 后 单 击 “ 提 交 ” 按 钮 进行 数据 处 理 。 表 单 
数据 提交 给 自身 ， 通 过 判断 是 否 为 提交 操作 来 处 理 数据 。 处 理 数据 通过 调查 类 Vote 的 对 象 
来 调用 父 类 DBSQL 的 updateData0 方 法 实现 。 编 辑 调 查 界 面 如 图 7.5 所 示 。 

和 
是 否 让 用 : 。 局 月 a 
图 7.5 编辑 调查 
代码 如 下 : 


<?php 


require_once('../config.inc.php"); \ 71/ 
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require_once(INCLUDE PATH . vote.incphp): 
$vote = new Vote(); 
$info = $vote->getInfo($_GET['id'],$vote->_name); 
$year = date("Y™"); 
Jist($start year$start_ month,$start day) = explode("-".date('Y-m-d',$info['F_VOTE START])); 
list($end_year,$end_month,$end_ day) = explode("-",date('Y-m-d',$info['F_VOTE END")): 
if($_SERVER['REQUEST_METHOD'] 一 'POST') // 判 断 是 否 为 提交 请 求 
{ 
$data[F VOTE TITLE'] = $_POST['title']: 
$data['F_VOTE START'] = mktime(0,0,0,$_POSTT['start_ m'],$_POSTT['start_ d'"],$_POSTT['start y]); 
$data['F_VOTE_ END'] = mktime(0,0.0,$ POST['end m]$_ POST['end_d].$_ POST['end_y]); 
$data['F_VOTE ITEM_ TYPE'] =$_POST['type']: 
$data[l'F_VOTE IS _ DISPLAY']= $_ POST['display]; 
if($vote->updateData($vote->_name,$_POST['id"],$data)) // 判 断 是 否 操 作成 功 
echo "操作 成 功 "; 
else 
echo "操作 失败 "; 
echo "<a href="VoteList.php 人 > 返回 </a>"; 
exit); } 
让 
?> 
<form name="forml1" action="" method="post" onsubmit="javascript:checkO:"> 
<table width="60%" border="0" align="center" cellpadding="0" cellspacing="0" class="]_table"> 
<tr class="title"> 
<td colspan="2" align="left">&nbsp:</td> 
</tr> 
<tr class="] field"> 
<td align="right"> 调 查 标题 ，</td> 
<td><input name="title" type="text" id="title" size="40" value="<?php echo 
$info[F_ VOTE _TITLE]?>" /></td> 
</tr> 
<tr class="] field"> 
<td align="right"> 所 属 类 型 : 
<td><select name="type" 1 
<2php 
foreach ($vote-> type as $key => $value) 
{ 


echo "<option value=$key"; 

这 $info[F VOTE ITEM_ TYPE'] — $key) 
echo " selected='selected"": 

echo ">$value</option>"; 


</select> </td> 
</tr> 
<tr class="] field"> 
<td width="24%" align="right"> 开 始 时 间 : </td> 
<td width="76%"> 
<select name="start y" id="start y"> 
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<?php 
for($i=1;$1<=($year+1):$i++) 
{ 


echo "<option value=$1"; 
这 $i 一 $start_year) 

echo " selected='selected"™"; 
echo ">$i</option>"; 


</select> 
年 
<select name="start_m" id="start_m" onchange="javascript:register_buildDay(this.value);"> 
<?php 
for($i=1;$1<=12:;$i++) 
{ 
if($i< 10) 
$i='0 .9$i; 
echo "<option value=$i"; 
这 $i 一 $start_month) 
echo " selected='selected"; 
echo ">$i</option>"; 


</select> 
月 
<select name="start_d" id="start_d"> 
<2php 
echo "<option value='$start_day'>$start_day</option>"; 
?> 
</select> 
日 </td> 
</tr> 
<tr class="] field"> 
<td align="right"> 结 束 时 间 : </td> 
<td> 
<select name="end _y" id="end y"> 
<?php 
for($i=1;$1<=($year+1);$i++) 
{ 
echo "<option value=$1"; 
1f($1=— $end_year) 
echo " selected='selected"™": 
echo ">$1</option>"; 


} 


?> 

</select> 

年 

<select name="end_m" id="end_m" onchange="javascript:register_buildDay(this.value);"> 
<?php 
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for($i=1:;$i<=12;$i++) 


{ 
if($i< 10) 
$i="0'. $i; 
echo "<option value=$i"; 
这 $i 一 $end_month) 
echo " selected='selected"™": 
echo ">$i</option>"; 
上 
?> 
</select> 
月 
<select name="end d" id="end d"> 
<?php 
echo "<option value='$end_day'>$end_day</option>"; 
?> 
</select> 
日 </td> 
</tr> 
<tr class="] field"> 
<td align="right"> 是 否 启 用 : </td> 
<td><input name="display" type="radio" value="1"<?php if($info['F_VOTE IS_DISPLAY'] = 1) 
echo "checked='checked";?> /> 
启用 
<input type="radio" name="display" value="0"<?php if($info['F_VOTE IS_DISPLAY'] — 0) 
echo "checked='checked":?> /> 
禁用 </td> 
</t> 
<tr class="title"> 
<td colspan="2" align="center"><input type="submit" name="Submit" value=" 提 交 " /> 
&nbsp; 
<input type="reset" name="reset" value=" 重 置 " /> 
<input name="id" type="hidden" id="id" value="<?php echo $_GET["id']?>" /></td> 
</tr> 
</table> 
<table align="center" border="0" cellpadding="0" cellspacing="0" width="98%"> 
<tbody><tr> 
<td>&nbsp;</td> 
</tr> 
</tbody></table> 
</form> 


<script language="javascript"> 
function checkIsValidDate(str) 
{ 


这 str —"") 
Tetum true; 
var arrDate = str.split(™-"); 
if(parseInt(arrDate[0],10) < 100) 
arrDate[0] = 2000 + parseInt(arrDate[0],10) + ""; 
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var date = new Date(arrDate[0],(parseInt(arrDate[1],10) -1)+"",arDate[2]); 
if(date.getYear( 一 arrDate[0] 
&& date.getMonth() 一 (parseInt(arrDate[1],10) -1)+"" 
&& date.getDate() 一 arrDate[2]) 
Tetum true; 
else 
Tetum false:; 


} 


function checkDateEarlier(strStart,strEnd) 


{ 


if(checkIsValidDate(strStart) 一 false || checkIsValidDate(strEnd) 一 false) 

Tetum false; 
if((strStart 一 "" )|(stEnd 一 "7 

Tetum true; 
Var arrl = strStart.split(™-"); 
Var arr2 = strEnd.split("-"); 
var datel = new Date(arrl[0],parseInt(arrl[1].replace(/^0/,""),10) - Larrl[2]): 
Var date2 = new Date(arr2[0],parseInt(arr2[1].replace(/^0/,""),10) - 1,arr2[2)); 
if(arrl[1].length 一 1]) 

arrl[1] = "0" +arl[1]; 
if(arrl[2].length =— 1) 

arrl[2] = "0" + arrl[2]: 
if(arr2[1].length =— 1) 

arr2[1] = "0" + arr2[1]; 
if(arr2[2].length =— 1) 

arr2[2]="0" + arr2[2]; 
var dl = arrl[0] + arrl[1] + arrl[2]; 
var d2 = arr2[0] + arr2[1] + arr2[2]; 
if(parseInt(d1,10) > parseInt(d2,10)) 

return false; 
else 
retum true; 


} 
String.prototype.len = functionO{ 
return this.replace(/[^\x00-\xff]/g,"aa").length; 
上 
function checkO 
{ 
Var Start = document.form! .start_y.value + "-" + document.form!].start_m.value + "-" + document. 
forml. start_d.value; 
Var End = document.forml .end y.value + "-" + document.forml.end_m.value + "-" + document. 
forml. end_d.value; 


if(document.form!1 .title.valw 


{ 
alert(' 请 填写 调查 名 称 ); 


documentformltitle.focus0O; 
Tetum false: 
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if(document.form! .title.value.len() > 100) 


alert(' 调 查 标题 不 能 超过 100 个 字 ') 
documentforml .title.focus(); 
Tetum false; 


} 
if(!checkDateEarlier(Start,End)) 


alert(' 开 始 日 期 因 不 能 小 于 结束 日 期 "); 
Tetum false; 
} 
} 
</script> 
比较 添加 调查 和 编辑 调查 文件 ， 可 以 看 出 它们 的 代码 很 相似 ， 不 同 的 是 在 编辑 时 多 了 
提取 编辑 信息 的 内 容 并 显示 出 来 。 那 么 可 以 将 添加 调查 和 编辑 调查 文件 合并 处 理 ， 只 需要 
增加 一 个 判断 即 可 。 代 码 如 下 : 


$vote = new Vote(); 


这 $_GET[id]) // 判 断 是 否 有 编辑 信息 的 ID 
{ 
S$info = $vote->getInfo($_GET['id'],$vote->_name); // 提 取 编 辑 信 息 内 容 
. 
这 $_SERVER[REQUEST_ METHOD] 一 POST') 
{ 
$datal'F_VOTE TITLE'] =$_POST['title']: 
$datal'F VOTE_START'] = mktime(0.0.0.8_POST[start_ m].$_ POST[start_d].$_ POST[start y]): 
$data[F_ VOTE _ END']= mktime(0.0.0.$_ POST['end m'],$ POST['end d'],$_POST['end y")); 
$data[F VOTE ITEM TYPE'] =$_POST['type']: 
$datal'F VOTE IS_DISPLAY'] = $ POST['display']: 
if($_POST[‘id’]) // 判 断 是 否 有 编辑 信息 的 IJD 
{ 
这 $vote->updateData($vote-> name,$_ POST['id].$data)) /执行 编辑 操作 
{ 
echo "操作 成 功 "; 
echo "<a href="VoteList.php 人 > 返回 </a>"; 
exit(); 
区 
}else 
{ 
这 $vote->insertData($vote-> name.$data)) /执行 添加 操作 
echo "操作 成 功 "; 
echo "<a hre 仁 "VoteList.php 人 > 返回 </a>"; 
exitO; 
yy } 
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5.， 删除 调查 文件 DelVote php 


该 文件 的 功能 是 删除 调查 及 相关 数据 。 该 文件 由 调查 列表 页 面 “ 操 作 ” 列 的 “[ 删 除 ]” 
超 链接 连接 过 来 传递 调查 ID 参数 。 删 除数 据 通过 调查 类 Vote 的 对 象 调用 父 类 DBSQL 的 
delData() 方 法 来 实现 。 代 码 如 下 : 


<?php 

TIequire_once(../config.inc.php'); 
require_once(INCLUDE PATH . vote.inc.php); 
$vote = new Vote(); 
if($vote->delData($_GET['id"])) 


{ 
echo "操作 成 功 <br>"; 
echo "<a href=' VoteList.php> 返 回 </a>"; 
exit(); 

} 

else 

{ 
echo "操作 失败 <br>"; 
echo "<a href=' VoteList.php> 返 回 </a>"; 
exit(); 

} 

?> 


6.， 调查 选项 列表 文件 ItemList.php 
该 文件 的 功能 是 显示 调查 选项 信息 表 中 的 数据 列表 。 该 文件 由 调查 列表 页 面 “ 操 作 ” 
列 的 “[ 选 项 管理 ]” 超 链接 连接 过 来 传递 调查 ID 参数 。 该 文件 通过 类 Vote 的 对 象 调 用 父 类 
的 getItemList0 方 法 实现 。 通 过 调查 选项 列表 页 面 可 以 连接 到 添加 、 编 辑 、 删 除 和 设置 选项 
顺序 页 面 。 调 查 选项 列表 界面 如 图 7.6 所 示 。 
让 


届 理 祭 题 : 您 对 癌 站 的 漂 意 程度? 


1 10 次 
2 15 次 注入 册 阶 | 
3 油 襄 0 
+ 相 帘 满 访 人 | 
LE LED 
图 7.6 调查 选项 列表 
代码 如 下 : 
<?php 
require_once('../config.inc.php"); 
require_once(INCLUDE PATH . vote.inc.php): 
$vote = new Vote(); 
S$list = $vote->getItemList($_GET[id]); 
?> 
<table width="60%" border="0" align="center"> N\ 71 
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S$info = $vote->getInfo($_GET['id'],$vote->_name); 
<td> 调 查 标题 : <?php echo $info['F_VOTE_TITLE']?> </td> 
</table> 
<table width="60%" border="0" align="center" cellspacineg="0" class="] table 1" id="table_ 1"> 
<tr class="title"> 
<td width="10%"> 序 号 </td> 
<td width="50%"> 选 项 标题 </td> 
<td width="19%"> 统 计 </td> 
<td width="21%"> 操 作 </td> 
</tr> 
<2php 
if($list) 
{ 
foreach($list as $key => $value) 
{ 
?> 
<tr class="] field"> 
<td align="left"><?php echo ($key + 1)?></td> 
<td align="left"><?php echo $value['F_ITEM_TITLE']?></td> 
<td align="left"><?php echo $value['F_ITEM COUNT']?> 次 </td> 
<td align="left"><a href="EditItem.php?id=<?php echo $value['F_ID']?>&voteid=<?php echo 
'$value[F_ID_VOTE_INFOT?>">[ 编 辑 ]</a><a href="DelItem.php?id=<?php echo $value[F ID]?> 
&voteid =<?php echo $_GET['id]?>"> [删除 ]</a> </td> 


<tr> 


<td colspan="9" align="center"><input type="submit" name="Submit3" value=" 添 加 选项 "onclick="javascript: 


window.location='AddItem.php?voteid=<?php echo $_GET['id]?>" />&nbsp;<input type="button" name="Submit" 
value=" 设 置 顺序 "onclick="javascript:window. location= 'SetOrder.php? voteid=<?php echo $_GET['id]?>" /> 
</td> 


</tr> 
</table> 


7. 添加 、 编 辑 调查 选项 文件 OperItem.php 
该 文件 的 功能 是 增加 指定 调查 的 选项 和 编辑 指定 调查 选项 的 信息 。 添 加 调查 选项 界面 如 


图 7.7 所 示 , 该 文件 由 调查 选项 列表 页 面 中 的 “添加 选项 ”按钮 连接 过 来 传递 调查 ID 参数 。 
编辑 调查 选项 界面 如 图 7.8 所 示 ， 该 文件 由 调查 选项 列表 页 面 “操作 ” 列 的 “[ 编 辑 ]” 超 链 
接连 接 过 来 传递 调查 ID 参数 、 选 项 ID 参数 。 这 里 添加 和 编辑 作为 一 个 文件 来 处 理 。 判 断 
当 有 选项 ID 参数 传递 时 为 编辑 状态 , 提取 该 选项 信息 并 显示 。 用 户 编辑 或 添加 完 表单 数据 


后 和 


ff 击 “提交 ”按钮 进行 数据 处 理 。 数 据 处 理 通 过 调查 类 Vote 的 对 象 调用 父 类 的 insertData0 


方法 实现 ， 编 辑 通 过 调用 updateData() 方 法 实现 。 


国 畏 PhP:MysQL 开发 项 目 教 各 


ET 
图 7.7 添加 调查 选项 


一 一 
图 7.8 编辑 调查 选项 


代码 如 下 : 


<2php 
Tequire_once(../config.inc.php); 
require_once(INCLUDE PATH . vote.inc.php); 
$vote = new Vote(); 
$title =" 添 加 调查 选项 " 
这 $_GET[id]) // 判 断 是 否 有 编辑 选项 DD， 有 则 提取 记录 
{ 
$info = $vote->getInfo($_GET['id'],$vote-> item); 
$title =" 编 辑 调 查 选 项 "; 


} 
if($_SERVER['REQUEST METHOD'] =— 'POST') // 判 断 是 否 提 交 请 求 
{ 


$data[F ID VOTE INFO]=$_POST[voteid']: 
$data[F_ITEM_TITLE]= $_POST['title]; 
$data['F_ITEM_COUNT'] =0; 
$data['F_ITEM_ORDER'] = 0: 


这 $_POST[id]) /有 选项 ID 参数 ， 则 执行 编辑 操作 
{ 
if($vote->updateData($vote-> item,$_POST['id].$data)) /判断 是 否 操作 成 功 


echo "添加 操作 成 功 <br>"; 
echo "<a hre 人 TtemListphp?id={$_ POST[voteid]}> 返 回 </a>"; 
exit(); 
}else{ 
echo "添加 操作 失败 <br>"; 
echo "<a href='TtemList.php?id={$_POST['voteid]} 人 > 返回 </a>"; 


exit():; 
} 
}else{ /无 选项 ID 参数 ， 则 执行 添加 操作 
if($vote->insertData($vote-> item,$data)) // 判 断 是 否 操作 成 功 


echo "编辑 操作 成 功 <br>"; 
echo "<a href='TtemList.php?id={$_POST['voteid]} 人 > 返回 </a>"; 
exit(); 
}else{ < 
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echo "编辑 操作 失败 <br>"; 
echo "<a href='TtemList.php?id={$_POST['voteid]} 人 > 返回 </a>"; 


exit(); 
} 
} 
} 
?> 
<table width="100%" border="0" cellpadding="0" cellspacing="0"> 
<tr> 
<td height="32" background="/images/lefttop.jpg" class="head"> 调 查 管理 >{S$title}</td> 
</tr> 
</table> 


<form name="forml1" action="" method="post" onsubmit="javascript:check();"> 
<table width="60%" border="0" align="center" cellpadding="0" cellspacing="0" class="] table"> 
<tr class="title"> 
<td colspan="2" align="left">&nbsp;</td> 
</tr> 
<tr class="] field"> 
<td width="24%" align="right"> 调 查 标题 ，</td> 
<td width="76%"> 您 对 网 站 的 满意 程度 ? </td> 
</tr> 
<tr class="] field"> 
<td align="right"> 选 项 标题 ，</td> 
<td><input name="title" type="text" id="title" size="40" value="<?php echo $info[F ITEM _TIILE']?>" 
</td> 
</tr> 
<tr class="title"> 
<td colspan="2" align="center"><input type="submit" name="Submit" value=" 提 交 " /> 
&nbsp; 
<input type="reset" name="reset" value=" 重 置 " /> 
<input type='hidden' name="id" id="id" value="<?php echo $_GET['id]?>"> 
<input type='hidden' name="voteid" id="voteid" value="<?php echo $_GET[voteid]?>"> 
</td> 
</t> 
</table> 
<table align="center" border="0" cellpadding="0" cellspacing="0" width="98%"> 
<tbody><tr> 
<td>&nbsp;</td> 
</tr> 
</tbody></table> 
</form> 
<script language="jJavascript"> 
function checkO 
{ 


// 判 断 标题 是 否 为 空 ， 是 则 弹出 提示 框 


if(document.form! .title.value 


{ 


alert(' 请 填写 选项 标题 "): 
document.form!1 .focusO; 
Tetum false; 
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</script> 

8. 选项 顺序 设置 文件 SetOrderphp 

该 文件 的 功能 是 设置 调查 选项 的 显示 顺序 。 该 文件 由 调查 选项 列表 页 面 中 的 “设置 顺 
序 ” 按 钮 连接 过 来 传递 调查 ID 参数 。 用 户 在 顺序 文本 框 中 输入 顺序 数值 后 单 击 “提交 ” 设 
置 按钮 进行 数据 处 理 。 选 项 按 数 值 顺 序 从 大 到 小 排列 。 数 据 提交 到 本 页 判断 是 否 为 提交 操 
作 并 进行 处 理 。 数 据 的 处 理 通 过 调查 类 Vote 的 对 象 调用 父 类 的 setOrder() 方 法 实现 。 选 项 
顺序 设置 界面 如 图 7.9 所 示 。 

和 
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图 7.9 选项 顺序 设置 
在 调查 类 文件 vote.inc.php 中 加 入 下 列 代码 : 
eg 
* 功能 : 设置 指定 调查 的 选项 顺序 
* 参数 : $id 选项 ID 数组 ，$order 选项 顺序 数组 
* 返回 : TRUE OR FALSE 
"yy 
public function setOrder($id,$order) 
{ 
if($id) 
{ 
S$this->begintransaction(); 
ty { 
foreach ($id as $key => $value) 
发 
$sql= "UPDATE ". $this-> item ." SETF_ITEM_ORDER = {$order[Skey]} 
WHEREF ID = $value"; 


S$this->update($sq)); 
b 
}catch (Exception $e) 
{ 
S$this->rollback(); 
retum false; 
} 
S$this->commit(); 
} 
Tetum true; 
} NI 
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下 面 的 代码 定义 了 一 个 设置 调查 选项 顺序 的 函数 ， 该 函数 在 选项 顺序 设置 文件 中 被 调 
了 。 代 码 如 下 : 


<?php 

require_once('../config.inc.php"); 
require_once(INCLUDE PATH . 'vote.inc.php"); 

S$vote = new Vote():; 

$list = $vote->getItemList($ GET['voteid']); 

S$info = $vote->getInfo($_GET['voteid'],$vote->_name); 
if($_SERVER['REQUEST_METHOD'] — 'POST') 


{ 
if($vote->setOrder($_POST['id'"],$_POST['order'"])) 
{ 
echo "操作 成 功 <br>"; 
echo "<a href=TtemList.php?id={$_GET['voteid]} 作 返回 </a>";'SetOrder.php?id={$_GET['voteid"]}' 
> 返回 </a>"; 
exit(); 
}else{ 
echo "操作 失败 <br>"; 
echo "<a href=' ItemList.php?id={$_GET['voteid]} 作 返回 </a>";'SetOrder.php?id={$_GET['voteid]}' 
> 返回 </a>"; 
exit(); 
} 
} 
?> 
<table width="100%" border="0" cellpadding="0" cellspacing="0"> 
<tr> 
<td height="32" background="/images/lefttop.jpe" class="head"> 调 查 管理 > 调查 选项 顺序 设置 </td> 
</tr> 
</table> 


<form name="forml1" action="" method="post"> 
<table width="60%" border="0" align="center"> 
<tr> 
<td> 调 查 标题 ，<?php echo $info[F_VOTE_TITLE']?></td> 
</tr> 
</table> 
<table width="60%" border="0" align="center" cellspacing="0" class="] table_1" id="table_1"> 
<tr class="title"> 
<td width="10%"> 序 号 </td> 
<td width="63%"> 选 项 标题 </td> 
<td width="279%0"> 顺 序 </td> 
</tr> 
<2php 
if($list) 
{ 
foreach ($list as $key => $value) 
{ 


> 
<tr class="] field"> 


<td align="left"><?php echo ($key+1)?> 
<input name="id[]" type="hidden" id="id[]" value="<?php echo $value['F_ID']?>" /></td> 
<td align="left"><?php echo $value[F_ITEM_TITLE']?></td> 


<td align="left"><input name="order[]" type="text" id="order[]" value="<?php echo $value['F_ITEM 
_ORDER']?>" size="10" /></td> 
</tr> 
<?php 


<tr> 
<td colspan="8" align="center"><input type="submit" name="Submit" value=" 提交 设置 " 广 
<input type= "hidden" name="voteid" id="voteid" value= "<?php echo $_ GET[id]?>"></td> 
</tr> 
</table> 
</form> 


9.， 删除 调查 选项 文件 DelItem.php 


该 文件 的 功能 是 删除 指定 选项 记录 。 该 文件 由 调查 选项 列表 页 面 “ 操 作 ” 列 的 “[ 删 除 ]” 
超 链 接连 接 过 来 传递 调查 ID 参数 、 选 项 ID 参数 。 选 项 的 删除 通过 类 Vote 的 对 象 调用 父 类 
的 delItemData() 方 法 来 实现 。 代 码 如 下 : 


<2php 

Tequire_once(..Jconfig.inc.php'); 

Tequire_once(INCLUDE PATH . "vote.inc.php); 

$vote = new Vote(); 

if($vote->delItemData($_GET['id'"])) // 判 断 是 否 操 作成 功 


echo "操作 成 功 <br>"; 
echo "<a href='TtemList.php?id={$_GET['voteid]} 人 > 返回 </a>"; 
exit(); 

}else{ 
echo "操作 失败 <br>"; 
echo "<a href='TtemList.php?id={$_GET['voteid]} 人 > 返回 </a>"; 
exit(); 

上 


?> 

10. 用 户 统计 信息 列表 文件 UserListphp 

该 文件 的 功能 是 提取 指定 调查 的 用 户 统计 信息 列表 。 该 文件 由 调查 列表 页 面 “操作 ” 
列 的 “[ 用 户 统计 信息 ]” 超 链接 连接 过 来 传递 调查 ID 参数 。 用 户 统计 信息 列表 以 分 页 显示 ， 
每 页 显示 10 条 记录 。 分 页 的 实现 通过 页 码 来 计算 每 页 提取 记录 的 开始 位 置 。 计 算 公式 为 开 
台 位 置 =( 页 码 -1)X 每 页 显示 数量 。 用 户 统 计 信 息 列 表 界 面 如 图 7.10 所 示 。 


nif 
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图 7.10 用 户 统计 信息 列表 
年 
代码 如 下 : 
<?php 


require_once('../config.inc.php"); 
Tequire_ once(INCLUDE PATH . vote.inc.php); 
$vote = new Vote(); 


S$cur_page =$_GET['page']; // 取 得 当前 页 码 
if(!$cur_page) 
$cur page = 1; // 如 果 无 页 码 ， 则 默认 为 第 一 页 


Slist = $vote->getUserList($_GET['id],$cur page); 
$count = $vote->getUserCount($_GET['id]): 


$pagecount = ceil($count/$vote-> pagesize); // 计 算 总 共 的 页 数 
if(!$pagecount) 
S$pagecount = 1; /如 果 无 总 页 数 ， 则 默认 为 1 
Surl = "?id={$_GET['id']} &page="; // 翻 页 跳 转 的 地 址 
?> 
<table width="100%" border="0" cellpadding="0" cellspacing="0"> 
<tr> 
<td height="32" background="/images/lefttop.jpg" class="head"> 调 查 管理 > 用 户 统计 信息 列表 </td> 
</tr> 
</table> 


<form name="forml1" action="" method="post"> 
<table width="80%" border="0" align="center"> 


<tr> 
<td><a href="AreaList.php?id=<?php echo $_GET['id]?>">[ 点 击 查看 区 域 统计 ]</a></td> 
</tr> 
</table> 


<table width="80%" border="0" align="center" cellspacing="0" class="] table_1" id="table_1"> 
<tr class="title"> 

<td width="7%"> 序 号 </td> 
<td width="45%"> 用 户 IP</td> 
<td width="25%"> 所 在 区 域 </td> 
<td width="23%"> 投 票 时 间 </td> 
</tr> 

<?php 

if($list) 

{ 
foreach ($list as $key => $value) 

~ yy/ t 
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?> 


<tr class="] field"> 
<td align="left"><?php echo ($key + 1)?></td> 
<td align="left"><?php echo long2ip($value[F_USER IP'])?></td> 
<td align="left"><?php echo $value['F_USER AREA]?></td> 
<td align="left"><?php echo date("Y-m-d,H:i:s",$value[F_USER TIME'])?></td> 
</t> 
<2php 
} 
} 


?> 
<tr> 
<td colspan="9" align="center"><table width='100%' align='center border='0' cellspacing="0'> 
<tr> 
<tdalign="left"> 共有 <b><?php echo $count?></b> 信息 共 <font color=#FF0000> 
<b><?php echo $cur page?></b></font> / <b><?php echo $pagecount?></b> 页 每 页 <strong><?php echo 
$vote->_pagesize?> </strong></td> 
<td width="30"> 转 到 </td> 
<td width="50"><select name="page" style="width:50px" onchange="javascript:location.hre 人 = 
document. getElementById('url")+this.options[selectedIndex].value"> 
<2php 
for($i=1:$i<=$pagecount:$i++) 
echo "<option value="$i"; 
if($i 一 $cur page) 
echo "selected= selected'"; 
echo ">$i</option>"; 
} 
?> 
</select> 
<input type="hidden" name="url" value="<?php echo $url?>" /></td> 
<td width="15"> 页 </td> 
</tr> 
</table></td> 
</tr> 
</table> 
</form> 


11. 区 域 统计 文件 AreaListphp 

在 用 户 统 计 信息 文件 里 显示 了 统计 信息 的 列表 , 但 该 列表 对 信息 的 统计 不 能 一 目 了 然 。 
区 域 统计 文件 的 功能 就 是 按 区 域 统计 用 户 的 信息 。 该 文件 是 由 用 户 统计 信息 页 面 的 “[ 点 击 
查看 区 域 统计 ]” 超 链接 连接 过 来 传递 调查 ID 参数 的 。 区 域 统计 界面 如 图 7.11 所 示 。 
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图 7.11 区 域 统计 
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在 调查 类 文件 vote.inc.php 中 加 入 下 列 代码 : 
/** 

* 功能 : 按 区 域 统计 用 户 信息 

* 参数 : $id 调查 ID 

* 返回 : 数组 

可 
public function areaList($id) 


$sql ="SELECT COUNT(F_ID) AS CEF_ USER _ AREAEFROM " . $this-> user; 
$sql =" WHEREF ID VOTE INFO= $id GROUP BYF USER AREA"; 
Teturn $this->select($sq]l); 

} 


下 面 代码 定义 了 按 区 域 分 组 查询 用 户 统计 信息 表 的 函数 ， 该 函数 在 区 域 统计 文件 中 被 
调用 。 代 码 如 下 : 


<2php 
require_once('../config.inc.php"); 
require_once(INCLUDE PATH . vote.inc.php); 
$vote = new Vote(); 
Slist = $vote->areaList($_GET["id"]): 
?> 
<table width="100%" border="0" cellpadding="0" cellspacing="0"> 
<tr> 
<td height="32" background="/images/lefttop.jpg" class="head"> 调 查 管理 > 区 域 统计 </td> 
</tr> 
</table> 
<form name="forml1" action="" method="post"> 
<table width="60%" border="0" align="center" cellspacing="0" class="] table_1" id="table_1"> 
<tr class="title"> 
<td width="9%"> 序 号 </td> 
<td width="58%"> 区 域 </td> 
<td width="33%"> 次 数 </td> 


</tr> 

<2php 

if($list) 

{ 
foreach ($list as $key => $value) 
{ 

?> 
<tr class="] field"> 
<td align="left"><?php echo ($key + 1)?></td> 
<td align="left"><?php echo $value[F_USER AREA'?></td> 
<td align="left"><?php echo $value['C']?></td> 
</tr> 

<?php 


} 


> 
</table> 


</form> 
7.3.2 ”调查 显示 模块 


调查 显示 模块 的 功能 是 把 符合 条 件 的 调查 提取 并 显示 出 来 。 这 里 的 条 件 包 括 是 否 启用 
和 是 否 过 期 。 调 查 显 示 界 面 如 图 7.12 所 示 。 
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非常 满意 。 
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2. 您 对 网 站 的 哪些 版 块 满意 了 
促销 信息 
招商 信息 
团购 信息 
网 上 投诉 
人 才 招聘 
提交 查看 结果 


图 7.12 调查 显示 


这 里 需要 调查 类 文件 vote.inc.php 中 的 一 个 按 条 件 提取 调查 信息 的 方法 , 因此 不 需要 新 
增 方法 ， 而 只 需要 修改 原来 的 getVoteList0 方 法 即 可 。 代 码 如 下 : 

/*: 水 

* 功能 : 提取 调查 列表 

* 参数 : $where 查询 条 件 

* 返回 : 数组 

a 

public function getVoteList($where = "){ 

$sql = "SELECT * FROM" . $this->_name: 


if($where) // 如 果 参 数 有 值 ， 则 加 入 查询 条 件 
{ 
$sql .= "WHERE" . $where; 
: 
Teturn $this->select($sq]l); 
} 
调查 显示 代码 如 下 : 
<?php 


require_once("config.inc.php"); 
Tequire_once(INCLUDE _PATH . "vote.inc.php"); 
$vote = new Vote(); 
$time = time(); 
$where ="F_ VOTE IS DISPLAY = 1 ANDF VOTE END < $time":; 
S$list = $vote->getVoteList($where): 
if($list) 
机 
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foreach($list as $key => $value) // 循 环 显示 调查 
{ 
Sitem = $vote->getItemList($value['F_ID']): // 提 取 指 定 调查 的 选项 


?> 
<form name="form <?php echo $value['F_ID']?>" method="post" action="Deal.php"> 
<table border="0" align="center" cellpadding="0" cellspacine="0"> 


<tr> 
<td><strong><?php echo ($key+1)?>. <?php echo $value['F_VOTE _TITLE']?></strong></td> 
</tr> 
<tr> 
<td> 
<?php 
if($item) 
《 
foreach(S$item as $val) /循环 显示 调查 选项 
{ 
if($value['F_VOTE_TYPE'] =— 1) // 判 断 调查 选项 的 形式 ， 以 不 同方 式 显示 
echo "<input type='radio' name='item' value="{$val['F_ID"]}>"; 
else 
echo "<input name='item[]' type='checkbox' id="item[]' value= {f$val[F_ ID]》 />"; 
echo $val[F_ ITEM_TITLE'] . "<br>"; 
} 
} 
?> 
</td> 
</t> 
<tr> 


<td><input type="submit" name="Submit" value=" 提 交 '"> 
<input type="button" name="Submit2" value=" 查 看 结果 "> 
<input type="hidden" name="id" value="<?php echo $value['F_ID']?>"> 
</td> 
</tr> 
</table> 
</form> 
<?php 


所 注意 
由 于 可 能 会 有 几 个 调查 同时 满足 条 件 ， 那 么 就 会 有 多 个 表单 ， 这 些 表单 的 名 称 不 能 相 
同 。 本 例 中 的 处 理 方 法 是 将 表单 的 名 称 写成 form + 调查 ID 的 方式 。 
7.3.3 投票 处 理 模块 


NS 投票 处 理 模块 的 功能 是 对 投票 用 户 的 信息 进行 合法 性 检查 ， 把 合法 用 户 的 投票 数据 写 
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入 数据 库 。 需 要 提取 的 用 户 信息 是 用 户 的 卫 , 通过 了 王 来 匹配 用 户 所 在 区 域 。 现 在 最 流行 的 
通过 IP 来 匹配 区 域 的 方式 就 是 利用 QQWry.dat 来 检索 区 域 ， 本 例 中 直接 调用 该 方法 。 代码 
如 下 : 


<?php 

require_once("config.inc.php"); 
require_once(INCLUDE PATH . "vote.inc.php"); 
require_once(INCLUDE PATH . "ip.inc.php"); 
$vote = new Vote(); 

S$ipclass = new IpO; 

$ip = getenv("REMOTE ADDR"); 

$ipl = getenv("HTTP X FORWARDED FOR"): 
$ip2 = getenv("HTTP_CLIENT IP"); 


($ipl) ? $ip = $ipl : null ; //$ipl 有 值 则 赋 给 认 
($ip2) ? $ip = $ip2 : null ; /Sip2 有 值 则 赋 给 jp 
S$longip = ip2long($ip); // 将 中 转化 为 整数 
这 !isset($_POST[iten]) /判断 用 户 是 否 选择 了 选项 
{ 
echo "<script>alert(' 您 未 选择 调查 选项 ! ");window.history.backQ;</script>"; 
exit(); 
} 
if($vote->checkIsValid($longip,$_ POST["id"])) // 判 断 用 户 是 否 合 法 
{ 
S$location = $ipclass-> ip2location getlocation($longip); /匹配 瑟 地 址 取得 所 在 地 区 
$vote->updateResult($_ POST['item'].$_ POST['id],$Slongip.$location): /更 新 数据 库 表 
header("Location:Resultphp?id={$_POST['id]}; // 跳 转 到 结果 页 面 
}else{ 


echo "<script>alert(' 您 已 经 投 过 票 了 !'),windows.location='Result.php?id={$_POST["id']}'</script>"; 
/不 合法 则 提醒 并 跳 转 到 结果 页 面 
exit(); 
上 


?> 

上 面 代码 在 取得 IP 时 用 了 3 个 预定 义 变量 ， 分 别 是 REMOTE ADDR、HTTP X_ 
FORWARDED FOR 和 HTTP_ CLIENT IP。getenv("REMOTE_ADDR") 用 于 取得 客户 端 地 
址 ， 如 果 客 户 端 用 的 是 代理 (客户 端 下 为 127.0.0.1， 代 理 卫 为 61.135.150.76)， 那 么 该 方 
法 取得 的 地 址 为 127.0.0.1。getenv("HTTP X FORWARDED FOR") 可 以 取得 代理 地 址 ， 但 
是 HITP X_ FORWARDED FOR 是 HITP 头 协议 的 一 部 分 ， 很 容易 伪造 ， 所 以 这 里 用 到 了 
HTTP_CLIENT _ 了 P。 

这 段 代 码 调用 了 checkIsValid() 方 法 来 检查 用 户 的 合法 性 ， 调 用 updateResult(0 方 法 来 更 
新 数据 表 ， 这 是 在 vote.inc.php 里 面 定义 的 。 代 码 如 下 : 

pe 

* 功能 : 检查 用 户 合法 性 


* 参数 : $ip 用 户 卫 ，$voteid 调查 ID 
* 返回 : TRUE OR FALSE 


所 {f 
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public function checkIsValid($ip,$voteid) 


{ 
$sql ="SELECTF IDFROM". $this-> user." WHEREF USER IP= $ip ANDF ID_ 
VOTE INFO = $voteid"; 
S$r = $this->select($sq]); 
if($r[0][F_ID] > 0) /如 果 该 卫 已 经 为 该 调查 投 过 票 ， 则 返回 FALSE 
Tetum false:; 
}else{ 
Teturn true; 
} 
} 
/下 


* 功能 : 处 理 投票 数据 和 用 户 信息 更 新 相关 数据 表 
* 参数 : $item 调查 选项 ID，$voteid 调查 ID，S$ip 用 户 全 ，$location 用 户 所 在 区 域 


* 返回 : TRUE 
wy 
public function updateResult($item,$voteid, $ip,$location) 
{ 
iflis_array($item)) // 判 断 item 是 否 为 数组 ， 是 则 为 多 选调 查 ， 循环 处 理 数据 
{ 
S$this->begintransaction(); // 开 始 事务 处 理 
ty{ 
foreach ($item as $value) 
{ 


$sql = "UPDATE " .$this-> item." SETF ITEM COUNT=F ITEM COUNT+1 
WHEREF ID= $value"; 
Sthis->update($sql): 

} 
$data = array(); 
$data[l'F_USER IP'] = $ip: 
S$data[F_USER_TIME]= time0: 
$data['F_USER AREA'] = $location; 
$data['F_ID_VOTE INFO'] = $voteid; 
$this->insertData($this->_ User.$data): 

}catch (Exception $e){ /出 现 异 常 ， 则 回 滚 
S$this->rollback(); 

$ 

$this->commitO: /正常 提交 

Tetum true; 

}else{ 

S$this->begintransaction(): // 开 始 事务 处 理 

try{ 
$sql ="UPDATE " .Sthis-> item ."SETF ITEM COUNT=F ITEM COUNT+1 

WHEREF ID = $item": 

S$this->update($sq]); 
$data = array(); 
$data['F_USER IP'] = $ip: 
S$data[F_USER_TIME]= time0: 


$data['F _ USER AREA'] = $location; 
$data['F ID VOTE INFO'] = $voteid; 
S$this->insertData($this-> user,$data); 

}catch (Exception $e){ // 出 现 异常 ， 则 回 深 
S$this->rollback(); 


; 
S$this->commit(); // 正 常 提 交 
Tetum true; 


} 
7.3.4 调查 结果 显示 模块 


调查 结果 显示 模块 的 功能 是 把 调查 结果 按 比例 显示 。 调 查 结果 界面 如 图 7.13 所 示 ， 该 
页 面 是 由 投票 处 理 页 面 跳 转 或 单 击 调查 显示 页 面 中 的 “查看 结果 ”按钮 连接 过 来 传递 调查 
ID 参数 的 。 比 例 计 算是 用 单个 选项 的 投票 数 除 以 所 有 投票 数 。 比 例 柱 图 的 显示 长 度 就 是 每 


个 选项 的 比例 。 
您 对 网 站 的 满意 程度 ? 
非常 满意 | | 1011.76% 
满意 ES 30 35.29% 
一 般 [| 25 29.41% 
不 好 [| 20 23.53% 
图 7.13 ”调查 结果 
代码 如 下 : 
<?php 
require_once("config.inc.php"); 
TIequire_ once(INCLUDE PATH . "vote.inc.php"); 
$vote = new Vote(); 
这 $_GET[id]) /判断 是 否 有 传递 参数 
{ 
S$info = $vote->getInfo($_GET['id'],$vote->_name); 
if(!isset($info[F_ID])) // 判 断 此 了 D 的 调查 是 否 存 在 
{ 
echo "无 此 调查 "; 
exit(); 
: 
$item = $vote->getItemList($_GET["id"]): 
$sum = 0; 
foreach ($item as $value) /计算 总 投票 交 
{ 
$sum += $value['F_ITEM_ COUNT': 
} 
}else{ /无 参数 则 提示 
echo "参数 错误 "; 
exit(); 


nf 
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} 
?> 
<table width="50%" border="0" align="center"> 
<tr> 
<td><?php echo $info['F_VOTE _ TITLE']?></td> 
</tr> 
</table> 
<table width="50%" border="0" align="center" cellpadding="3" cellspacing="2"> 
<2php 
if($item) 
{ 
foreach ($item as $value) 
{ 

S$percent = (@number format($value[F ITEM_COUNT]/$sum,2); ”// 计 算 每 个 选项 票数 所 占 比 例 

Slength = $percent . "%"; 
?> 

<tr> 
<td width="27%"><font color="#000000"><?php echo $value['F_ITEM TITLE']?></font></td> 
<td width="32%"><table height="12" cellspacing="1" cellpadding="0" width="<?php echo 
S$length?>" 
bgcolor="#000000" border="0"> 
<tr> 
<td bgcolor="#EF0000">&nbsp;</td> 
</tr> 
</table></td> 
<td width="41%"><span class="STYLE2"><?php echo $value['F_ITEM_ COUNT']?></span> 
<font color="#000000"> <?php echo $length?></font></td> 
</tr> 

<?php 
} 
> 
</table> 


[二 四 

判断 传递 参数 的 有 效 性 及 参数 是 否 为 室 、 是 否 有 效 。 本 例 中 就 是 判断 传递 的 调查 ID 

是 否 为 空 ， 该 调查 是 否 存在 。 还 有 一 点 就 是 计算 每 个 选项 所 占 比例 时 ， 需 要 加 上 人 @ 符 号 以 
屏蔽 错误 提示 。 因 为 当 总 票数 为 0 时 ， 进 行 除法 计算 就 会 报错 ， 这 样 会 使 浏览 者 感觉 系统 “ 


容错 性 不 好 。 


项 目 8 


支持 多 用 户 的 博客 系统 开发 


eg a 
> 支持 多 用 户 的 博客 系统 的 分 析 
六 ”支持 多 用 户 的 博客 系统 的 实施 步骤 


> 掌握 支持 多 用 户 的 博客 系统 的 分 析 
六 “动手 实现 支持 多 用 户 的 博客 系统 的 实施 步骤 


教学 基础 要 求 
了 解 支持 多 用 户 的 博客 系统 的 分 析 
动手 实现 支持 多 用 户 的 博客 系统 的 实施 步 双 


~ 
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澡 


任务 闻 用 户 的 博客 系统 开发 


任务 描述 


通过 项 目 7 的 学 习 ， 大 家 已 经 初步 了 解 PHP+MySQL 项 目 开发 ， 本 项 目 将 大 体 讲解 一 
下 支持 多 用 户 的 博客 系统 开发 过 程 。 
知识 汇总 


8.1.1 系统 分 析 


本 项 目 介 绍 一 个 支持 多 用 户 的 博客 系统 开发 过 程 。 虽 然 这 是 一 个 比较 简单 的 多 用 户 博 
客 系统 ， 但 是 它 基本 圳 括 了 一 个 博客 系统 应 具备 的 所 有 基本 功能 ， 是 一 个 有 一 定价 值 的 系 
统 。 本 项 目 将 给 出 该 系统 的 全 部 核心 代码 。 其 实 ， 建 议 读者 仅 将 给 出 的 代码 作为 一 个 参考 ， 
自己 亲自 动手 来 编写 相关 代码 。 这 样 可 以 锻炼 自己 复杂 代码 的 编写 能 力 ， 为 将 来 独立 开发 
PHP 十 MySQL 的 Web 应 用 系统 打下 基础 。 

在 支持 多 用 户 的 博客 系统 中 ， 可 以 分 为 3 大 类 用 户 : 注册 用 户 、 管 理 用 户 和 浏览 用 户 。 

注册 用 户 可 以 申请 博客 账号 、 添 加 博客 分 类 、 修 改 自 己 博客 分 类 、 添 加 博客 内 容 、 修 
改 博客 内 容 、 对 自己 博客 进行 常规 管理 、 修 改 本 博客 的 友情 链接 、 修 改 首 页 图 片 (banner 
和 博 主 头像 )、 修 改 博 主 的 话 等 。 

管理 用 户 的 功能 非常 简单 ， 就 是 设置 博客 用 户 的 状态 以 及 删除 用 户 。 

浏览 用 户 则 可 以 访问 博客 用 户 的 所 有 内 容 。 


8.1.2 ”实施 步骤 


1. 博客 功能 设计 

通过 对 多 用 户 博客 系统 的 分 析 ， 对 博客 系统 的 3 大 类 用 户 的 功能 做 如 下 设计 。 

注册 用 户 : 常规 设置 〈 博 客 页 面 的 显示 属性 和 标题 、 版 权 等 )、 友 情 链 接管 理 〈 添 加 、 
编辑 和 删除 自己 的 友情 链接 )、 首 页 图 片 管理 (banner 和 博 主 形象 图 片 )、 博 主 的 话 、 日 志 
的 分 类 〈 添 加 和 修改 )、 日 志 的 添加 、 日 志 的 管理 〈 编 辑 和 删除 ) 以 及 安全 设置 。 

管理 用 户 : 设置 注册 用 户 的 状态 、 删 除 现 有 的 注册 用 户 以 及 安全 设置 。 

浏览 用 户 : 根据 注册 用 户 设置 的 常规 设置 的 格式 来 访问 注册 用 户 添加 的 友情 链接 、 首 
页 图 片 、 站 长 的 话 、 日 志 分 类 、 日 志 的 具体 内 容 等 信息 。 

系统 功能 如 图 8.1 所 示 。 

2. 数据 库 与 表 设 计 


为 了 提高 访问 速度 ， 本 博客 系统 采用 数据 库 和 文件 并 存 的 方式 ， 数 据 库存 放 博 客 的 主体 
内 容 数据 ， 而 对 于 博客 的 页 面 属 性 ， 如 边 距 、 标 题 、 版 权 等 信息 ， 则 采用 文件 操作 的 方式 。 


\v 存储 博客 主体 内 容 数据 的 数据 库 名 为 blog db, 含有 6 个 数据 表 , 各 数据 表 之 间 的 关系 
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如 图 8.2 所 示 。 


CT 
让 一 一 一 [ 常规 设置 显示 属性 和 标题 、 版 权 ) | 一 一 | 显示 格式 | 一 
一 一 一 一 [ 友情 链接 管理 添加、 编辑 和 出 除 ) | -| 
首页 图 片 管理 (banner 和 博 主 形象 ) 
一 一 | 博 主 的 话 | - 
显示 内 容 | 一 
一 | 日 志 的 分 类 添加 和 修改 ) ] - 
日 志 的 添加 按照 分 类 深 加 ) 
日 志 的 管理 《编辑 和 删除 ) 


图 8.1 系统 功能 设计 示意 图 


blog_type_info 


浏览 用 户 


注册 用 户 


blog_db 
支持 多 用 户 的 博客 系统 


pic_info 


manage_user 


User_pW 
tag 
user_name, T time 
id 
last_time) 
user_info 


blog_comm_info 


图 8.2 数据 库 设 计 及 数据 表 间 关系 示意 图 
6 个 数据 表 详 细 的 字段 设计 分 别 如 表 8.1 一 表 8.6 所 示 。 


表 8.1 manage _info (管理 用 户 信息 数据 表 ) 


管理 用 户 名 
管理 用 户口 令 
最 后 登录 时 间 


manage user varchar(20) 


manage pW varchar(32) 


last_ time datetime 
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编 号 字 段 名 字段 意义 备 注 
1 id 
user name rchar 用 户 名 
3 User pw 用 户 密码 
本 0: 靶 该 
4 tag char (2) 标志 位 让 we 
3 r time datetime 用 户 注 册 时 间 
6 last time 最 后 登录 时 间 
表 8.3 blog_type_info (blog 类 型 信息 数据 表 ) 
编号 字 段 名 字段 意义 备 ” 注 
1 id 
2 User id 用 户 ID 等 同 于 表 user info 中 的 id 
3 type_name varchar (10) 类 型 名 称 
4 add time datetime 添加 时 间 
5 show_order int (10) 显示 序号 
表 8.4 blog_info (博客 信息 数据 表 ) 
编 号 | 字段 名 字段 意义 备注 
1 家 [in 
2 user id | int | 用 户 ia 等 同 于 表 user info 中 的 id 
3 peid | int | 关 型 等 同 于 表 blog type_info 中 的 id 
4 title 博客 标题 
5 cont 博客 内 容 
6 add time 添加 时 间 
表 8.5 blog_comm_info (博客 评论 信息 数据 表 ) 
编 ”号 字 段 名 字段 意义 备注 
1 id 自动 编号 
2 blog id int (11) 博客 ID 等 同 于 表 blog info 中 的 id 
3 comm name varchar (32) 评论 人 
4 cont text 评论 内 容 
3 add time datatime 添加 时 间 
表 8.6 pic_info (系统 图 片 信息 数据 表 ) 
编 ”号 字 段 名 字段 意义 备注 
id 动 编号 
2 addr Varchar(32 轩 片 地 址 
= 0: 隐藏 
示 / 隐 藏 标志 他 a 
3 tag 示 / 隐 藏 标志 位 1; 显示 
1: 顶部 banner 
立 置 a 
tarpet 片 位 2: 站 长 形象 
、\/ 5 user id 户 id 等 同 于 表 user info 中 的 id 


PHP+MySQL 开发 项 目 教程 


文件 操作 采用 存储 变量 的 方法 ， 使 用 时 直接 包含 文件 并 使 用 相关 变量 即 可 ， 如 页 边 距 、 
背景 颜色 、 友 情 链接 、 博 主 的 话 等 均 存放 在 config 文件 夹 中 的 config*.inc、link*.txt、 
sta_say*.txt 文件 中 ， 其 中 * 为 用 户 的 ID。 例 如， 有 一 个 用 户 注 册 ， 他 的 id 为 1， 用 户 进行 
基本 的 设置 后 在 config 文件 夹 中 就 会 多 出 configl.inc、linkl1.txt、sta_say1.txt 这 3 个 文件 。 

3. 文件 结构 设计 

真正 开发 系统 时 要 把 界面 设计 放 在 首位 ， 设 计 完 界面 后 ， 再 进行 代码 的 编写 。 在 代码 


的 编写 过 程 中 ， 首 先 对 整个 系统 进行 严格 的 文件 结构 设计 ， 实 现 一 步 到 位 。 
本 项 目的 所 有 文件 清单 及 存放 路 径 如 表 8.7 所 示 。 
表 8.7 文件 结构 
根 目录 中 的 内 容 | 子 目录 中 的 文件 备注 
oiled 存放 网 页 布局 参数 、 头 信息 和 版 权 设置 。 
*# 为 注册 用 户 的 id 
存放 注册 用 户 设置 的 友情 链接 信息 。 
eo *# 为 注册 用 户 的 id 人 
ed 存放 注册 用 户 的 “ 博 主 的 话 ”的 内 容 。 户 配置 文件 
四 *# 为 注册 用 户 的 id 
系统 中 每 增加 一 个 注册 用 户 , 本 文件 夹 内 会 自动 增加 3 个 文件 。 
本 文件 夹 必须 要 有 可 写 权 限 ， 否 则 程 请 就 会 报错 
CSS.CSS CSS 文件 ， 系 统 显示 格式 定义 SR 
inc fontinc CSS 文件 ， 注 册 用 户 显示 格式 定义 ee 人 
footphp 版 权 文件 ， 系 统 版 权 显 示 
headl.php 头 文件 ， 注 册 用 户 网 站 头 部 显示 
head2.php 头 文件 ， 管 理 员 登 录 后 系统 头 部 显示 
head.php 头 文件 ， 系 统 头 部 显示 文件 夹 : 存放 被 包含 
人 myfootphp 版 权 文件 ， 注 册 用 户 博客 版 权 显示 文件 
myfunction.php 函数 类 库 文件 
mysql inc php 
blog add.php 日 志 添 加 文件 
blog edit.php 日 志 编 辑 文件 
blog manage.php ”| 日 志 管 理 文件 
general.php 日 志 的 常规 设置 文件 文件 夹 : 注册 用 户 后 
Se head php 头 文件 ， 注 册 用 户 登 录 后 系统 头 部 显示 “| 台 管理 文件 
key php 安全 设置 文件 
link php 友情 链接 管理 文件 
logout php 


{1 
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根 目 录 中 的 内 容 | 子 目 录 中 的 文件 二 省 
menu.php 注册 用 户 管理 菜单 文件 
module addphp 日 志 分 类 添加 管理 文件 
pic add.php 图 片 管理 文件 文件 夹 : 注册 用 户 后 
Pe session.php 网 站 访问 权限 文件 台 管 理 文件 
sta_say.php 博 主 的 话 管理 文件 
user.php 注册 用 户 管理 的 界面 布局 文件 
文件 夹 : 存放 本 系统 界 
面相 关 的 图 片 和 注册 
Be 用 户 上 传 的 banner 和 
自己 形象 图 片 
index.php 管理 员 管理 首页 ， 注 册 用 户 管理 文件 
logoutphp 管理 员 退 出 登录 文件 文件 夹 : 存放 管理 员 
ee session.php 管理 员 管 理 权限 文件 管理 文件 


super key.php 
数据 库 设 计 .doc 
关系 图 .sdr 


blog db.sql 
blog comm.php 
day_blog.php 
index.php 
系统 文档 - 
install.php 


loginl .php 


管理 员 安全 设置 文件 

存放 本 系统 详细 的 数据 库 设计 

存放 本 系统 数据 库 中 数据 表 之 间 的 关联 
关系 的 关系 图 

数据 库 导 出 文件 

按 天 查看 博 主 日 志文 件 

系统 首页 文件 

数据 库 安装 文件 (建议 安装 完成 后 删除 该 
交 件 》 

注册 用 户 登 录 文 件 


存放 本 系统 有 关 的 
文档 


login.php 
menu.php 


myblog.php 


系统 管理 员 登 录 文件 
注册 用 户 博客 菜单 文件 
注册 用 户 博 客 首页 文件 


time.php 


日 历 文件 


type_blog.php 


4. 算法 与 代码 的 实现 


按 日 志 分 类 访问 日 志 的 文件 


由 于 本 系统 较为 复杂 ， 所 含 的 文件 也 比较 多 ， 如 果 一 一 写 出 其 详细 的 算法 需要 非常 
大 的 篇 幅 。 下 面 就 3 类 不 同 用 户 的 访问 或 操作 流程 简单 地 进行 描述 ， 如 图 8.3 一 图 8.5 


所 示 。 
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0 D33) 


管理 操作 (删除 注册 用 户 、 


设置 博客 状态 、 安 全 设置 ) 存在 
某 注册 用 户 的 博客 


Er 按 类 型 分 类 访问 || 按 具体 哪 天 访问 


图 8.3 管理 用 户 流程 简 图 图 8.4 浏览 用 户 流程 简 图 


| 


N 


(> 常规 设置 
是 
N 
> 友情 链接 管理 


Y 博 主 的 话 


| 


预览 


| 
或 
间 


日 志 添加 


安全 设置 


匡 匡 
就 就 于 
囊 3 
站 洋 


图 8.5 注册 用 户 流程 简 图 


有 关 数 据 的 存储 ， 本 系统 中 不 仅 使 用 了 数据 库 ， 还 用 到 了 文件 ， 而 文件 存 取 数 据 的 方 
法 也 用 到 以 下 两 种 。 

(1) 直接 存放 : 使 用 PHP 程序 读 取 、 写 入 文本 文件 的 内 容 。 

(2) 在 文本 文件 中 存储 变量 : 使 用 PHP 程序 包含 该 文件 ， 并 且 在 程序 中 直接 使 用 
过 


数据 库 创 建 的 方法 有 两 种 : 
(1) 从 phpmyadmin 的 可 视 化 操作 界面 创建 数据 库 、 数 据 表 。 
(2) 在 命令 提示 符 下 创建 数据 库 和 数据 表 ， 有 具体 的 SQL 命令 如 下 。 
nL 
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创建 数据 库 : 
CREATE DATABASE "blog db': 


创建 数据 表 blog_ comm info: 


CREATE TABLE IF NOT EXISTS blog comm info' ( 
"id' int(11) NOT NULL auto_increment, 
mblog id int(11) default '0', 
‘comm name' varchar(32) NOT NULL, 
"cont text NOT NULL, 
'add_ time' datetime default '0000-00-00 00:00:00', 
UNIQUE KEY 'id (id) 

% 


创建 数据 表 blog_info: 


CREATE TABLE IF NOT EXISTS blog info' ( 
"id int(11) NOT NULL auto_increment, 
"user id int(11) NOT NULL, 
‘type_id' int(11) NOT NULL, 
‘title' varchar(100) NOT NULL, 
‘cont' text NOT NULL., 
"add_time' datetime default '0000-00-00 00:00:00"', 
UNIQUE KEY 'id' (id) 
站 


创建 数据 表 blog type_info: 


CREATE TABLE IF NOT EXISTS 'blog type_info'( 
"id int(11) NOT NULL auto_increment, 
mser id int(11) NOT NULL, 
"type_name' varchar(10) NOT NULL， 
'add_time' datetime default '0000-00-00 00:00:00', 
"show_order int(10) default '0', 
UNIQUE KEY 'id' (id) 

); 


创建 数据 表 manage_info: 


CREATE TABLE IF NOT EXISTS 'manage_info' ( 
"id int(11) NOT NULL auto_increment, 
manage_User varchar(20) NOT NULL., 
manage_ pw' varchar(32) NOT NULL., 

"last_time' datetime default '0000-00-00 00:00:00', 
UNIQUE KEY 'id' (id) 
); 


创建 数据 表 pic_info: 


CREATE TABLE IF NOT EXISTS pic info' ( 
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"id int(11) NOT NULL auto_increment, 
addr varchar(32) NOT NULL. 


"tag' char(2) default '1', 


"target char(2) default '0', 
mser id int(11) NOT NULL, 


UNIQUE KEY 'id' (id) 


创建 数据 表 user_info 


CREATE TABLE IF NOT EXISTS "user info' ( 
"id int(11) NOT NULL auto_increment, 
user_ name' varchar(20) NOT NULL, 
user_ pw' varchar(32) NOT NULL., 


"tag' char(2) default 1', 


T_time' datetime default '0000-00-00 00:00:00', 
"last_time' datetime default '0000-00-00 00:00:00', 


UNIQUE KEY 'id' (id) 
» 


下 面 按照 类 库 文件 、 


装 程序 文件 、 注 册 用 户 文件 、 管 理 用 户 文件 、 浏 览 用 户 文件 的 


顺序 依次 给 出 本 系统 的 核心 文件 和 代码 。 


(1) 类 库 文 件 。 


数据 库 服务 器 连接 类 库 文件 ， 即 inc 文件 夹 下 mysqlLphp 的 具体 代码 如 下 : 
回 inc/mysqlinc.php 


<! -- 文 件 mysql.php--> 
<?php 
class mysql{ 


/连接 服务 器 、 数 据 库 以 及 执行 SQL 语句 的 类 库 


public $database; 
public $server_username; 


public $server_userpassword; 


function mysql0 


{ /构造 函数 初始 化 所 要 连接 的 数据 库 
S$this->server_username="root"; 
S$this->server_userpassword="root"; 


Miend mysql0 
function link($database) 


{ /连接 服务 器 和 数据 库 


if ($database—""){ 


S$this->database="news_manage"; 


}else{ 


S$this->database=$database; 


} 
// 连 接 服务 器 和 数据 库 


这 $id-mysql connect(localhost,$this->server Usemame, $this-> server_ 


userpassword)) { 


if(!mysql_select_db(S$this->database.$1d)){ ~、(/ 
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echo "数据 库 连接 错误 !1! "; 

exit; 

} 

}else{ 

echo "服务 器 正在 维护 中 ， 请 稍 后 重 试 1!! "; 


exit; 


} 

}Wend link($database) 

function excu($query) 

{ // 执 行 SQL 语句 
if($result=mysql_query($query)){ 
return $result; 

}else{ 

echo mysql_errorO; 

echo "sql 语句 执行 错误 !!! 请 重 试 !11"; 
exit; 

} 

} Wend exec($query) 

} Wend class mysql 

?> 


使 用 服务 器 数据 库 连接 类 库 后 ， 如 果 MySQL 数据 库 服 务 器 更 换 密码 或 系统 移植 到 别 
的 环境 中 ， 只 需要 更 改 第 10、11 行 的 用 户 和 密码 即 可 。 

根据 类 可 以 复 用 的 思想 ， 上 面 的 服务 器 数据 库 连 接 的 类 库 文件 一 旦 编写 完成 ， 以 后 再 
开发 其 他 系统 时 就 不 需要 再 次 编号， 直接 把 该 文件 复制 过 去 即 可 使 用 。 

回 inc/myfunction.php 

<2php 

class myfunction{ 


1/1/ 字符 转换 : 向 数据 库 中 插入 或 更 新 时 用 /WU/ 
function str_to($str) 


时 
$str=str_replace(" ","&nbsp:",$str); /把 空格 替换 成 html 的 字符 串 空 格 
$str=str_replace("<","&lt:",$str); // 把 html 的 输出 标志 正常 输出 
$str=str_replace(">","&gt:",$str); // 把 html 的 输出 标志 正常 输出 
$str=nl2br($str); // 把 回 车 替换 成 html 中 的 <br> 
Tetum $str; 


3} 
/1/ 字 符 转换 : 从 数据 库 中 读 出 显示 在 表单 文本 框 中 用 W111/ 
function str_to2($str) 


& 
$str=str_replace("&nbsp;"," ",$str); // 把 空格 替换 成 html 的 字符 串 空格 
$str=str_replace("<br />","",$str); // 把 html 的 输出 标志 正常 输出 
retum $str; 
} 
/JS 弹出 信息 框 


function js_alert($message, $urD) { 
echo "<script language=javascript>alert(": 
echo $message; 
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echo "");location.href—"; 
echo $url; 
echo ™;</script>"; 


} 
// 判 断 是 否 为 整数 
function int_estimation($num){ 
if (eregi("“[0-9]+$", $num)){ 


Teturn true; 
}else { 
Tetum false: 
; 
} 
// 类 型 id 返回 类 型 名 称 
function type_idto_name($type id){ 
S$folie=new mysql; 


Sfolie->link("™"); 
$query="select type_name from blog_type_info where id='$type_id"™; 
S$rst=$folie->excu($query); 
Sinfo=mysql fetch_array($rst); 
return $info["type_name"]; 


} 
/博客 信息 表 中 的 类 型 id 返回 博客 类 型 名 称 

function blog_type idto name($type_id){ 
S$folie=new mysql; 
Sfolie->link(""); 
$query="select * from blog_type_info where id='$type_id"; 
S$rst=$folie->excu($query); 
S$info=mysql_fetch_array($rst); 
Teturn $info["type_name"]; 


} 
1 分 页 函数 返回 :首页 上 一 页 [1][2][.…] 下 一 页 尾 页 等 超 链 接 WWN 
function page($query,$page_id,$add,$num per page){ 
Il! include "mysql.ine"; 
1/1/ 使 用 方法 为 : 
JW/ $myf=new myfunction: 
/111 $query=""; 
11/11/ Smyf->page($query,$page_id,$add,$num per_page); 
/JW $bb=$aa->excu($query); 
$bb=new mysql: 
global $query; // 声 明 全 局 变量 
$bb->link(""): 
S$page id=$_ GET[page id]; // 接 收 page_id 
if($page 1d—""){ 
S$page id=1; 
} 
S$rst=$bb->excu($query); 
$num=mysql num rows($rst); 
if ($num—0){ 
echo "无 相关 记录 ! <br>"; 
}else{ 
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Spage_num=ceil($num/$num per page); 
for ($i=1;$i<—$page_num:$i++){ 
if($page id—$i){ 


echo "[$1]"; 
}else{ 
echo "&nbsp:[<a href=?".$add."page id= $1>".$1." </a>]"; 
} 
; 
if ($page id—1){ 
S$page_up=1; 
jelse{ 


S$page_up=$page id-1; 
了 
if ($page id=——$page num){ 
S$page_down=$page_num:; 
}else{ 
S$page_down=$page id+1; 
> 
if ($page_ id<$page_num and $page num>1){ 
echo "<a href=?".$add."page_id=$page_down> 下 一 页 </a>"; 
} 
if ($page id>]1 and $page id<=$page num){ 
echo "<a href=?".$add."page_id=$page_up> 上 一 页 </a>"; 
} 
echo "&nbsp;&nbsp; 第 ".$page_id." 页 , 共 ".$page_num." 页 "; 
$page_jump=$num per_page*($page id-1); 
$query=$query." limit $page_jump,$num per page"; 


(2) 安装 程序 文件 。 
回 install.php 


<2php 

include "inc/mysql.inc.php"; 

$aa=new mysql; 

$bb=new mysql; 

$aa->link("mysql"); 

$query="CREATE DATABASE "blog db": 

if($aa->excu($query){ 

echo "数据 库 创 建成 功 ! <br>"; 

} 

$bb->link("blog_db"); 

// 创 建 表 : manage_user info 

$query="CREATE TABLE ‘manage_info' ( 
"id int(11) NOT NULL auto_increment, 
"manage_User varchar(20) NOT NULL., 
manage_pwW' varchar(32) NOT NULL., 
"last_time' datetime default '0000-00-00 00:00:00", 
UNIQUE KEY 'id' (id) 
六 

a yy/ Sbb->excu($query); 
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echo "创建 表 : manage info 成 功 ! <br>"; 
// 创 建 表 : user_ info 
$query="CREATE TABLE "user info' ( 
"id int(11) NOT NULL auto_increment, 
user_ name' varchar(20) NOT NULL, 
mser_ pw' varchar(32) NOT NULL. 
"tag' char(2) default '1', 


'T_time' datetime default '0000-00-00 00:00:00', 
"last_time' datetime default '0000-00-00 00:00:00", 


UNIQUE KEY id (iid) 
a 

$bb->excu($query); 

echo "创建 表 : user_info 成 功 ! <br>"; 

// 创 建 表 : blog_type_info 

$query="CREATE TABLE 'blog type_info' ( 
"id int(11) NOT NULL auto_increment, 
"user id int(11) NOT NULL, 
"type_name' varchar(10) NOT NULL, 


'add_time' datetime default '0000-00-00 00:00:00', 


'show_order' int(10) default '0', 
UNIQUE KEY 'id' (id) 
ys 
$bb->excu($query):; 
echo "创建 表 : blog_type_info 成 功 ! <br>"; 
// 创 建 表 : blog_info 
$query="CREATE TABLE 'blog_info' ( 
"id int(11) NOT NULL auto_increment, 
mser id int(11) NOT NULL, 
‘type_id' int(11) NOT NULL, 
‘title' varchar(100) NOT NULL, 
‘cont' text NOT NULL, 


'add_time' datetime default '0000-00-00 00:00:00', 


UNIQUE KEY 'id' (id) 
ys 
$bb->excu($query); 
echo "创建 表 : blog info 成 功 ! <br>"; 
// 创 建 表 : blog_comm info 
$query="CREATE TABLE 'blog comm info' ( 
"id int(11) NOT NULL auto_increment, 
mblog id int(11) default '0', 
‘comm _ name' varchar(32) NOT NULL., 
'cont' text NOT NULL., 


"add_time' datetime default '0000-00-00 00:00:00", 


UNIQUE KEY 'id' (id') 
$bb->excu($query); 


echo "创建 表 : blog_comm info 成 功 ! <br>"; 


// 创 建 表 : pic_info 
$query="CREATE TABLE 'pic_info'( 
"id int(11) NOT NULL auto_increment, 
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"addr varchar(32) NOT NULL., 
"tag' char(2) default '1', 
‘target' char(2) default '0', 
"user jd int(11) NOT NULL., 
UNIQUE KEY 'id' (id) 
$bb->excu($query); 
echo "创建 表 : pic_info 成 功 ! <br>"; 
// 初 始 化 管理 员 用 户 名 和 密码 
$query="INSERT INTO ‘manage_info' VALUES(1,'admin','admin','0000-00-00 00:00:00)"; 
if($bb->excu($query)){ 
echo "初始 化 管理 员 用 户 名 和 密码 :admin,admin<br>"; 
} 
echo "OK!"; 
?> 


(3) 用 户 注 册 文件 。 
回 loginl.php 


<2php 

include "inc/mysqlinc.php": 

include "inc/myfunction.php"; 
include "inc/head.php"; 

S$folie=new mysql; 

$crazy=new myfunction; 
S$folie->link("™"); 

// 接 收 变量 

Sregister tag=$_ GET["register tag"]: 
S$up_register=$_POST["up_register"]; 
S$up_login=$_POST["up_login"]; 


// 验 证 用 户 登录 信息 
if($up_login=—1){ 
$user name=$ POST["user name"]; 
$query="select * from user_info where User_name='$user_ name' and tag ="1"; 
S$rst=$folie->excu($query); 
if(mysql num rows($rst)>=1){ 
S$info=mysql_fetch_array($rst); 
$user pw=$_ POST["user pw"]; 
if($user pw 一 $info["user pw"]){ 
$_SESSION["user_name"]=$user_name; 
$_SESSION["user id"]=$info["id"]; 
$_SESSION["user tag"]="1"; 
$today=date("Y-m-d H:i:s"); 
$query = "update user info set last_ time Stoday where id-'Sinfofid]": 
//$query="insert into user_info(user name' "user pwW', last_time) 
//values('$user_name','$user pw,$today)": 
$folie->excu($query): 
$crazy->js_alert(" 登 录 成 功 !","manage/user.php"); 
ce yy/ jelse { 


Scrazy->js_alert(" 用 户 名 或 密码 错误 !","index.php"): 


} 
}else { 
Scrazy->js_alert(" 用 户 名 或 密码 错误 ! ","index.php"); 


} 


// 判 断 用 户 注册 信息 ， 并 写 入 数据 库 
if($up_register—1){ 
$user _ name=$ POST["user name"]; 
if($user name!=""){ 
$query="select * from user_info where user_name='$user name"; 
S$rst=$folie->excu($query); 
if(mysql num rows($rst)<1){ 
$user pwl=$ POST["user pw1"]; 
$user pw2=$_ POST["user pw2"]; 
if($user pwl=—$user pw2 and $user pwl1!=""){ 
S$r_time=date("Y-m-d H:i:s"); 
$query="insert into user_info('user_name', "user pw', 'T_ time) 
values('$user name','$user pwl','$r time")"; 
S$rst=$folie->excu($query); 
i1f($rst) { 
$crazy->js_alert(" 注 册 成 功 ! ","index.php"); 
} 
}else { 
$crazy->js_alert(" 两 次 输入 的 密码 不 一 致 ， 请 重新 输入 ! ","index.php?re 
gister_tag=1"); 


} 
}else { 
$crazy->js_alert(" 用 户 名 已 存在 ! ","index.php?register_tag=1"); 
} 
} 
?> 


<table width="752" border="0" cellpadding="0" cellspacing="0" style="border-collapse:collapse"> 
<tr> 
<td width="1" bgcolor="#CCCCCC"></td> 
<td colspan="2" align="center" valign="top"><table width="490" border="0" cellpadding="0" 
cellspacing="0" bgcolor="#FFFFFF"> 
<tr> 
<td align="center" valign="top"> 
<!-- 系 统 说 明 表 格 ， 纯 HTML 代码 ， 略 --> 
<!-- 系 统 简介 ， 用 户 登 录 --> 
<2php 
if($register tag!=1){ 
?> 
<!-- 用 户 登录 表单 、 表 格 ， 纯 HTML 代码 ， 略 --> 
<?php 
Jelse { 
和 
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<!-- 用 户 注册 -> 
<!-- 用 户 注册 表单 、 表 格 ， 纯 HTML 代码 ， 略 --> 
<2php 
; 
?2><br></td> 
</tr> 
</table></td> 
<td width="1" bgcolor="#CCCCCC"></td> 
</tr> 
<tr> 
<td height="1" colspan="3" bgcolor="#CCCCCC"></td> 
</tr> 
</table> 
<?php 
include "inc/foot.php"; 
?> 


回 manage/user.php 


<2php 
include "session.php"; 
include "../inc/mysql.inc.php"; 
include "../inc/myfunction.php"; 
include "head.php"; 
S$folie=new mysql; 
S$crazy=new myfunction; 
$folie->link("™"); 
?> 
<table width="752" border="0" cellpadding="0" cellspacing="0" style="border-collapse:collapse"> 
<tr> 
<td width="1" height="199" bgcolor="#CCCCCC"></td> 
<td width="490" align="center" valign="top"><table width="490" border="0" cellpadding="0" 
cellspacing="0" bgcolor="#FFFFFF"> 
<tr> 
<td height="400" align="center" valign="top"> 
<br /><?php 
$target=$_GET["target"]; 
if($target—""){ 


echo "一 欢迎 您 登录 多 用 户 博客 管理 后 台 ! 二 <br> 一 = 单 击 右 侧 链 接 , 进行 相关 操作 。 
. }else{ 

$target.=".php"; 
include $target; 

} 

?></td> 

</tr> 
</table></td> 


<td width="1" bgcolor="#CCCCCC"></td> 
<td width="257" align="center" valign="top"><?php include "menu.php"; ?></td> 
\y/ <td width="1" bgcolor="#CCCCCC"></td> 
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</tr> 


<tr> 
<td height="1" colspan="3" bgcolor="#CCCCCC"></td> 
<td width="258" colspan="2" bgcolor="#CCCCCC"></td> 
</tr> 
</table> 
<?php 
include "../inc/foot.php"; 
?> 


回 manage/general.php 


<?php 
$config tag=$ GET["config tag"]; 
$name="config".$_SESSION["user id"]; 
if ($config tag—1){ 
/接收 变量 
$margin top=$_ POST["margin-top"]; 
$margin_bottom=$_POST["margin-bottom"]; 
$background_color=$_POST["background-color"]:; 
S$title=$_POST["title"]; 
$copy_right=$_POST["copy-right"]; 
/构造 字符 串 
$str_in="<?php\n"; 
in.="global \$confg:;\n"; 
/网 页 布局 参数 \n"; 
\$config["margin-top'] = \"".$margin_top."\";\n"; 
\$config['margin-bottom'] = \"".$margin_bottom."\" 


/ 头 信息 和 版 权 设 置 \n"; 
$config['title] = \"".S$title."\":\n"; 
\$config['copy-right] = \"".$copy_right."\";\n"; 
.="\n?>"; 
// 写 入 文件 
if ($fp=fopen("../config/$name.ine", "w")){ 
fwrite($fp,$str_in); 
felose($fp); 
} 
include "../config/$name.ine"; 
上 
@include "../config/$name.ine"; 
?> 
<br> 
<h4> 常 规 设 置 <h4> 


config["background-color] =\"".$background_color."\":\n"; 


<form id="form1l" name="form1l" method="post" action="user.php?target=general&config tag=1"> 
<table width="98%" border="0" align="center" cellpadding="0" cellspacing="1" bgcolor="#CCCCCC"> 


<tr> 


<td width="20%" height="20" align="right" valign="middle" bgcolor="#FFFFFF"> 上 边 距 : </td> 
<td width="80%" bgcolor="#EFFFFF"><input name="margin-top" type="text" value="<?php echo 


S$config['margin-top']?>" size="4"/> 
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像素 (在 英文 或 中 文 半角 下 输入 ， 和 否则 不 能 生效 ) </td> 
</tr> 
<tr> 


<td height="20" align="right" valign="middle" bgcolor="#EFFFFF"> 下 边 距 : </td> 
<td bgcolor="#FFFFFF"><input name="margin-bottom" type="text" value ="<?php echo 
S$config["margin-bottom']?>" size="4" /> 
像素 〈 在 英文 或 中 文 半 角 下 输入 ， 和 否则 不 能 生效 ) </td> 
</tr> 
<tr> 
<td height="20" align="right" valign="middle" bgcolor="#FFFFFF"> 网 页 背景 颜色 : </td> 
<td bgcolor="#FFFFFF"><input name="background-color" type="text" value="<?php echo 
S$config['background-color']?>" size="10" /> 
输入 以 # 开 头 的 6 位 十 六 进 制 数 的 颜色 值 〈 在 英文 或 中 文 半角 下 输入 ) </td> 
</tr> 
<tr> 
<td height="20" align="right" valign="middle" bgcolor="#FFFFFF">&nbsp; </td> 
<td bgcolor="#FFFFFF">&nbsp;</td> 
</tr> 
<tr> 
<td height="20" align="right" valign="middle" bgcolor="#FFFFFF"> 网 站 头 名 称 : </td> 
<td bgcolor="#FFFFFF"><input name="title" type="text" value="<?php echo $config['title]?>" 
size="30" /></td> 
</tr> 
<tr> 
<td height="20" align="right" valign="middle" bgcolor="#FFFFFF"> 版 权 信息 : </td> 
<td bgcolor="#FFFFFF"><input name="copy-right" type="text" id="copy-right" value="<?php echo 
S$config['copy-right']?>" size="40"/></td> 
</tr> 
<tr> 
<td height="20" colspan="2" align="center" valign="middle" bgcolor ="#FFFFFF"><input 
type="submit" name="Submit" value=" 提 交 " />&nbsp;&nbsp;&nbsp: &nbsp;&nbsp:;&nbsp:;&nbsp; 
<input type="reset" name="Submit2" value=" 重 置 " /> </td> 
</tr> 
</table> 
</form> 


加 manage/link.php 


<2php 
// 编 辑 友情 链接 
if($_GET["edit tag"]—1){ 
$name="link".$_SESSION["user id"]; 
if(!@$fp=fopen("../config/$name.txt","r"){ 
echo "未 创建 ! <br>"; 
Jelse{ 
$link name=$ GETI["link name"]; 
Slink name new=$ POST["link name new"]:; 
Slink addr new=$ POST["link addr new"]; 
@3rst=feets($fp,3000); ” // 读 取 
\y/ S$link=explode("|",$rst); 
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for ($i=0:$i<count($link):$i++) 


($1962=—0){ 
$j=$itl; 
if (Slink[$ij-—$link name){ 
Slink[$i]=S$link_ name new: 
$link[$j]-$link addr new:; 


} 
} 
} 
/构造 新 的 字符 串 
for ($i=0;$i<count($link);$i++){ 
if ($i=—0){ 
Slink_new=$link[$i]; 
}else{ 
$link new="|".$link[$i]; 
由 
/重新 写 入 


if ($fp=fopen("../config/$name.txt", "w"){ 
fwrite($fp, $link_new); 


fclose($fp); 
} 
} 
} 
} 
/添加 链接 


if($_GET["add tag"]—1){ 
S$link name new=$_ POST[link name new]; 
$link addr new=$ POST[link addr new]: 
if ($link name new!="" and $link addr new!=""){ 
$name="link".$_ SESSION["user id"]; 
@$fp=fopen("../config/$name.txt","r"); 
@Srst=fgets($fp,3000); ” // 读 取 
if ($rst=——""){ 
S$rst.=$link name new; 
S$rst.="|".$link_addr_new:; 
j}else{ 
S$rst.="|".$link_name new; 
S$rst.="|".$link_addr_new; 


} 
// 重 新 写 入 
if ($fp=fopen("../config/$name.txt", "w")){ 
fwrite($fp,$rsb): 
fclose($fp); 
} 
} 
上 
/删除 链接 
if($_GET["del tag"]—1){ 
S$link name=$ GET["link name"]; \ 177 
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$name="link".$_ SESSION["user id"]: 
if (!@S$fp=fopen("../config/$name.txt","r")){ 
echo "未 创建 ! <br>"; 
Jelse{ 
@Srst=feets($fp,3000); 。 // 读 取 
Slink=explode("|",$rst); 
for ($i=0;$i<count($link):;$i++) 
{ 
if ($91962=—0){ 
$j=$it+l; 
if ($link[$i]=—$link name){ 
$link[$1]=""; 
Slink[$)]=""; 
break: 
} 
上 
} 
/构造 字符 串 
for ($i=0;$1i<count($link);$i++) 
{ 
if ($link[$i]!=""){ 
if ($i==0){ 
$str_in=$link[$i]; 
j}else{ 
$str_in.="|".$link[$i]; 
} 


// 重 新 写 入 
if ($fp=fopen("../config/$name.txt", "w"){ 
fwrite($fp,$str_in); 
fclose($fp); 
} 
} 
} 
?> 
<br> 
<h4> 友 情 链接 管理 </h4> 
<table width="500" border="0" cellpadding="0" cellspacing="0"> 
<tr> 
<td colspan="5" bgcolor="#CCCCCC"></td> 
</tr> 
<tr align="center" valign="middle"> 
<td height="26"> 序 号 </td> 
<td height="26"> 显 示 效 果 </td> 
<td> 显 示 名 称 </td> 
<td height="26"> 链 接 网 址 </td> 
<td height="26"> 操 作 </td> 
</tr> 
、\/ <?php 
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/从 .configllink txt 中 读 出 数据 
$name="link".$ SESSION["user id"]:; 
于 (I@S$fp=fopen("../config/$name.txt",Tr)){ 
echo "未 创建 ! <br>"; 
}else{ 
(@Srst=fegets($fp,3000); ” // 读 取 
S$link=explode("|",$rst); 
1f ($rst!=""){ 
for ($i=0:$1<count($link):;$i++) 
‘ 
if ($1%2==0){ 
$j=$i+1; 
?> 
<tr> 
<td height="1" colspan="5" bgcolor="#CCCCCC"></td> 
</tr> 
<tr align="center"> 
<form id="form1" name="forml" method="post" action="user.php?target =link&edit tag=1 
&link _ name=<?php echo $link[$i]?>"> 
<td height="30" valign="middle"><?php echo (ceil($1/2)+1)?></td> 
<td height="30" valign="middle"><?php echo "<a href=".$link[$j]." target 
= _blank>".$link[$i]."</a>":2></td> 
<td height="30" valign="middle"><input name="link_name_ new" type ="text" size="10" 
maxlength="20" value="<?php echo $link[$i]?>" /></td> 
<td height="30" valign="middle"><input name="link_addr_new" type="text" size="20" maxlength="40" 
value="<?php echo $link[$j]2>" /></td> 
<td height="30" valign="middle"><input type="submit" name="Submit" value=" 修 改 "/> 
&nbsp;&nbsp;<a href="user.php?target=link&del tag=1&link name=<?php echo $link[$i]?>"> 删 除 
</a></td> 
</form> 
</t> 
<?2php 


} 
?> 
<tr align="center"> 
<form id="form1" name="form1" method="post" action="user.php?target =link&add tag=1"> 
<td height="30" valign="middle"><?php echo ($1/2)+1?></td> 
<td height="30" valign="middle">&nbsp;</td> 
<td height="30" valign="middle"><input name= "link name new" type="text" size="10" 
maxlength="20" /></td> 
<td height="30" valign="middle"><input name="link addr new" type="text" size="20" 
maxlength="40" /></td> 
<td height="30" valign="middle"><input type="submit" name="Submit" value =" 添 加 "/></td> 
</form> 
</tr> 
<tr> 
<td height="1" colspan="5" bgcolor="#CCCCCC"></td> 
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</tr> 
</table> 


加 manage/pic add.php 


<?php 
include "session.php"; 
$add tag=$ POST["add tag"]; 
if($add tag—1){ 
$target=$_ POST["target"]; 
if(!empty($_FILES['file name'][mame'])){ 
// 根 据 现 在 的 时 间 产 生 一 个 随机 数 
$randl=rand(0.9); 
S$rand2=rand(0,9); 
S$rand3=rand(0,9); 
$filename=date("Ymdhms").$rand1.$rand2.$rand3; 
S$oldfilename=$_FILES['file_ name'][mame']; 
Sfiletype=substr($oldfilename,strrpos($oldfilename,"."),strlen($oldfilename)- strrpos($oldfilename,".")); 
if(($filetype!="jpg)&&($filetype!=".JPG")&&($filetype!=".GIF'")&&($filetype!=".gif ) 
&&(Sfiletype!=".swf )&&($filetype!=".SWE')) { 
echo "<script>alert(' 文 件 类 型 或 地 址 错误 ");</script>"; 
echo "<script>location.href="?up_id=".$up_id."&menu id=".$menu id.";</script>"; 
exit: 
} 
if($_FILES['file name']['size]>2000000) { 
echo "<script>alert( 文 件 太 大 ， 不 能 上 传 );</script>"; 
echo "<script>location.href="?up_id=".$up_id."&menu id=".$menu id.";</script>"; 
exit: 
} 
Sfilename=$filename. $filetype; 
$savedir="../pic_sys/".$filename:; 
if(move_uploaded file($ FILES['file name']['tmp_name'],$savedir)){ 


$file name=basename($savedir): // 取 得 保存 文件 的 文件 名 (不 含 路 径 》 
// echo "<br> 文 件 上 传 成 功 ! 保存 为 :".$savedir; 
}else{ 


echo "<script language=javascript>"; 
echo "alert( 错 误 ， 无 法 将 附件 写 入 服务 器 !\n 本 次 发 布 失败 ! ):"; 
echo "<script>location.href="?up_id=".$up_id."&menu id=".$menu id.";</script>"; 
echo "</script>"; 
exit; 
} 
$query="insert into pic_ infoCaddr ,tag ,target ,user id ) values('$filename','l','$target', 
'$_SESSION[user id])": 
if($folie->excu($query){ 
$crazy->js_alert(" 恭 喜 您 ， 添 加 图 片 成 功 ! 请 继续 。","#"); 


} 


} 
、\/ /删除 图 片 操作 
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$del id-$_ GET["del id"]: 
if($del id!=""){ 


: 


$query="select * from pic_info where id='$del id and user id='$_ SESSION [user 1d]"; 
S$rst=$folie->excu($query):; 

$info=mysql fetch array($rst); 

S$pic_addr="../pic_sys/".$info["addr"]: 

unlink($pic_addr); 

$query="delete from pic_info where id='$del id and user id='$_SESSION [user id]"; 
S$rst=$folie->excu($query); 

echo "删除 成 功 !"; 


/显示 /隐藏 图 片 

$show tag=-$_GET["show tag"]; 
Spic id-$_ GET["pic id"]: 
if($show_tag=—=1 and $pic_id!=""){ 


$query="update pic_info set tag="0' where id="'$pic_id"™"; 
S$rst=$folie->excu($query); 


}else if($show_tag—0 and $pic id!=""){ 


} 


$query="update pic_info set tag="1' where id="$pic_id"™"; 
S$rst=$folie->excu($query); 


?> 

<h4> 图 片 管 理 </h4> 

<form enctype="multipart/form-data" action="user.php?target=pic_add" method ="post" name="form1" id="forml"> 
<div align="center"> 


<center> 
<table width="450" border="0" cellpadding="0" cellspacing="1" bordercolorlight="#cccecce" bordercolordatk= 
"#CCCCCC" bgcolor="#CCCCCC" id="AutoNum berl" style="border-collapse: collapse"> 

<tr> 

<td height="31" colspan="2" align="center" valign="middle" bgcolor ="#CCCCCC">&lt&lt 图 片 

添加 &gt;&gt;</td> 

</tr> 
<tr> 

<td width="20%" bgcolor="#FFFFFF" height="26" align="right"> 图 片 地 址 : </td> 

<td width="80%" height="12" bgcolor="#FFFFFF"><input type="file" name="file name" size="36" /></td> 
</tr> 
<tr> 

<td bgcolor="#FFFFFF" height="26" align="right"> 显 示 位 置 :</td> 

<td height="26" bgcolor="#FFFFFF"><select name="target"> 

<option value="1"> 顶 部 banner</option> 
<option value="2"> 博 主 形象 </option> 

</select> </td> 
</tr> 
<tr> 

<td width="123" bgcolor="#FFFFFF" height="27" align="right"> 添 加 人 : </td> 

<td width="439" height="27" bgcolor-"#EFFFFF">&nbsp:<?php echo $SESSION["user name"]?></td> 
</tr> 
<tr> 

<td bgcolor="#CCCCCC" height="31" align="right" colspan="2"> 


一 一 一 一、 项目 8 支持 多 用 户 的 博客 系统 开发 轩 


<p align="center"> 
<input type="submit" value=" 提 交 " name="B1">&nbsp;&nbsp;&nbsp; &nbsp; 
<input type="reset" value=" 重 置 "name="B2"></td> 
</tr> 
</table> 
</center> 
</div> 
<input type="hidden" name="add tag" value="1"> 
</form> 
<!-- 显 示 图 片 -> 
<2php 
$query="select * from pic_info where user id-'$ SESSION[user id]"; 
S$rst=$folie->excu($query); 
if(mysql_num rows(S$rst)>=1){ 
?> 
<table width="100%" border="1" cellpadding="0" cellspacing="0" bordercolor ="#CCCCCC" 
style="border-collapse:collapse"> 
<tr> 
<td width="5%" height="25" align="center"> 序 号 </td> 
<td width="79%" align="center"> 图 片 </td> 
<td colspan="2" align="center"> 操 作 </td> 
</tr> 
<?php 
$i=1; 
while($info=mysql_fetch_array($rst)){ 
?> 
<tr> 
<td width="5%" height="60" align="center"><?php echo $i:?></td> 
<td width="79%" align="center" valign="middle"><a href—="../pic_sys /<?php echo $info["addr"];?>" 
target="_blank"><img sre="../pic_sys/<?php echo $info["addr"]:?>" height="50" border="0"> 
</a></td> 
<td width="8%" align="center"> 
<?php 
if($info["tag"]—1){ 
?> 
<a href="user.php?target=pic_add&pic_id=<?php echo $info["id"]:?>&show tag=1"> 显 示 </a> 
<?php 
jelse { 
?> 
<a href="user.php?target=pic_add&pic_id=<?php echo $info["id"]:?>&show tag=0"> 隐 藏 </a> 
<?php 
} 
?></td> 


<td width="8%" align="center"><a href="user.php?target=pic_add&del 1d =<?php echo $info["id"];?>"> 
删除 </a></td> 
</t> 
<2php 
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> 
</table> 


<?php 
} 


?> 


加 manage/sta say.php 


<?php 
/接收 变量 
$sta_say=$_ POST["sta say"]; 
$name="sta_say".$ SESSION["user id"]; 
if ($sta_say!=""){ 
$sta_say=str_replace(" ","&nbsp:;",$sta_say); 
// 写 入 文件 
if ($fp=fopen("../config/$name.txt", "w")){ 
fwrite($fp,$sta_say); 


fclose($fp); 
} 

1; 

// 读 出 文件 


if (@$fp=file("../config/$name.txt")){ 
for ($i=0;$i<count($fp);$i++) { 
$str_out.=$fp[$1]; 
} 
上 
@include "../config/$name.ine"; 
?> 
<br><h4> 博 主 的 话 </h4> 
<table width="98%" border="0" cellpadding="0" cellspacing="0"> 
<tr> 
<td height="1" bgcolor="#CCCCCC"></td> 
</tr> 
<tr> 
<td height="30" align="left" valign="middle"> 请 在 下 面 的 表单 中 输出 博 主 的 话 </td> 
</tr> 
<tr> 
<td height="1" bgcolor="#CCCCCC"></td> 
</tr><form id="form1" name="forml1" method="post" action="user.php?target=sta_say"> 
<tr> 
<td height="200" align="center" valign="middle"> 
<textarea name="sta_say" cols="40" rows="12"><?php echo $str_out:?></textarea></td> 
</tr> 
<tr> 
<td height="30" align="center" valign="middle"><input type="submit" name="Submit" value= "提交 " 这 
&nbsp:&nbsp:&nbsp:&nbsp: 
<input type="reset" name="Submit2" value=" 重 置 "/></td> 
</tr></form> 
<tr> 
<td height="1" bgcolor="#CCCCCC"></td> 
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</tr> 
</table> 


加 manage/module add.php 


<?php 
include "session.php"; 
$page id-$_ GET["page id"]; 
S$edit tag=$ POST["edit tag"]; 
$Submit=$_POST["Submit"]: 
/接收 日 志 类 型 ， 并 写 入 数据 库 
if($Submit 一 "提交 "){ 
$type_name=$ POST["type_name"]; 
$show_order=$_POST["show_order"]; 
if($crazy->int_estimation($show_order)){ 
if($type_name!="" and $show_order!=""){ 
$add_time=date("Y-m-d H:i:s"); 
$query="insert into blog_type_info( ‘user id ,type name ,add _ time ,show_order ) 
values($_ SESSION[user id]','$type_name','$add time',$show_order)"; 
S$folie->excu($query); 
echo "<center><font color=#ff0000> 分 类 添加 成 功 ! </font></center>"; 
}else { 
$crazy->js_alert(" 类 型 名 、 序 号 都 不 能 为 空 ! ","user.php?target=module_add"); 


} 
}else { 
$crazy->js_alert(" 请 输入 一 整数 ! ","user.php?target=module_add"); 
} 
} 
// 接 收编 辑 信息 并 写 入 数据 库 


S$queren=$_POST["queren"]:; 
if($queren 一 "确认 "){ 
$blog_id=$_POST["blog id"]; 
S$edit_show_order=$_ POST["edit show_order"]: 
S$edit_ type name=$_ POST["edit type_name'"]: 
if($edit_show_order!="" and $edit_type_name!=""){ 
$query="update blog_type_info set show_order="$edit_show_order', 
type_name='$edit_type_name' where id='$blog id"; 
S$folie->excu($query); 
echo "<font color=#ff0000> 编 辑 成 功 ! </font>"; 
} 
} 
/删除 日 志 类 型 
$del id=$_GET["del id"]: 
if($del id!="){ 
$query="delete from blog type_info where id-'$del id": 
S$folie->excu($query); 
echo "<font color=#ff0000> 删 除 成 功 ! </font>"; 


} 


?> 
、W、 <- 添加 日 志 关 型 -> 


<h4> 日 志 分 类 </h4> 
<form action="user.php?target=module_add"method="post"> 
<table width="80%" border="1" cellpadding="0" cellspacing="0" bordercolor="#CCCCCC" 
style="border-collapse:collapse"> 
<tr> 


<td height="30" colspan="2" align="center" bgcolor="#CCCCCC">&lt:&lt: 日 志 分 类 添加 &gt:&gt:</td> 
</tr> 
<tr> 
<td width="20%" height="30" align="right"> 日 志 类 型 : </td> 
<td width="80%"><input type="text" name="type_name"></td> 
</tr> 
<tr> 
<td height="30" align="right"> 序 号 ; </td> 
<td><input type="text" name="show_order"></td> 
</tr> 
<tr> 
<td height="30"colspan="2" align="center"><input type="submit" name="Submit" value=" 提 交 "> 
&nbsp;&nbsp; <input type="reset" name="Submit2" value=" 重 置 "></td> 


</tr> 
</table> 
</form> 
<!-- 显 示 所 有 日 志 类 型 --> 
<2php 


$query="select * from blog _type_info where user id=-'$ SESSION[user id]' order by show_order"; 
Srst=$folie->excu($query); 
这 mysql_num_ rows($rst)>=1){ 
$add="user.php?target=module_add&"; 
Spagesize=3; 
$crazy->pagination($query,$page_id,$add,$pagesize); 
Srst=$folie->excu($query); 
.> 
<table width="70%" border="1" cellpadding="0" cellspacing="0" bordercolor ="#CCCCCC" 
style="border-collapse:collapse"> 
<tr> 
<td height="25" colspan="3" align="center" bgcolor="#CCCCCC">&lt:&lt: 日 志 类 型 管理 &gt:&gt:</td> 
</tr> 
<tr> 
<td width="10%" height="25" align="center"> 序 号 </td> 
<td width="60%" align="center"> 类 型 名 称 </td> 
<td width="30%" align="center"> 操 作 </td> 
</t> 
<2php 
$i=]; 
while($info=mysql fetch array($rst){ 
物 
<form action="user.php?target=module_add&page 1d=<?php echo $page id:?>" method="post"> 
<tr> 
<td width="10%" height="25" align="center"> 
<?php 
if($edit tag 一 9$D{ 
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?> 
<input type="text" name="edit_show_order" value="<?php echo $info ["show_order"]:?>" size="5"> 
<?php 
}else { 
echo $info["show_order"]; 
}2></td> 
<td width="60%"> 
<2php 
if($edit tag—$D){ 
?> 
<input type="text" name="edit type_name" value="<?php echo $info ["type_name"];?>"> 
<?php 
jelse { 
echo $info["type_name"]; 
}?></td> 
<td align="center"><table width="100%" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td width="50%" align="center"> 
<2php 
if($edit tag 一 9i){ 
> 
<input type="submit" name="queren" value=" 确 认 " class="input2"> 
<?php 
}else { 
?> 
<input type="submit" value=" 编 辑 " class="inputl"> 
<?php }?></td> 
<td width="50%" align="center"><a href="user.php?target=module_add&page_id=<?php 
echo $page id;?>&del id=<?php echo $info["id"];?>"> 删 除 </a></td> 
</tr> 
</table></td> 
</tr> 
<input type="hidden" value="<?php echo $1:?>" name="edit_tag"> 
<input type="hidden" name="blog_id" value="<?php echo $info["id"];?>"> 
</form> 
<2php 
S$i++; 
} 
?> 
</table> 
<?php 
}else { 
echo " 暂 无 日 志 分 类 。"; 
上 


?> 


回 ” manage/blog add.php 


<?php 
< yy/ include "session .php"; 
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$submit=$ POST["submit"]:; 
if($submit 一 "提交 "){ 
$type_name id=$ POST["type name id"]; 
$title=$_ POST["title"]; 
$cont=$ POST["content"]; 
$cont-$crazy->str to($conb:; /字符 转换 ， 使 其 支持 空格 和 换行 
$add time=date("Y-m-d H:i:s"); 
if($type_name id—"){ 
$crazy->js_alert(" 请 选择 日 志 类 型 ! ","userphp?target=blog_add"); 
}else if($title—""){ 
$crazy->js_alert(" 标 题 为 空 ! ","user.php?target=blog_add"); 
}else if($cont—""){ 
$crazy->js_alert(" 日 志 内 容 为 空 ! ","user.php?target=blog_add"); 
}else { 
$query="insert into blog_info(‘user id ,type id title ,cont， ‘add time’) 
values($_SESSION[user idj,Stype_name id''$title''$cont'$add time')": 
$folie->excu($query); 
$crazy->js_alert(" 日 志 添加 成 功 ! ","userphp?target=blog_add"); 


?> 
<br /> 
<h4> 书 写 日 志 </h4> 
<form id="form1" name="forml" method="post" action="user.php?target=blog add"> 
<table width="450" border="0" cellpadding="0" cellspacing="1" bgcolor ="#CCCCCC"> 
<tr> 
<td width="20%" align="right" valign="middle" bgcolor="#FFFFFF"> 选 择 日 志 类 型 </td> 
<td width="80%" height="26" align="left" valign="middle" bgcolor="#FFFFFF"> 
<select name="type_name id"> 
<option value="" selected="selected"> 请 选择 ...</option> 
<2php 
$query="select * from blog type_info where user_ id-'$ SESSION[user id] ' order by show_order"; 
S$rst=$folie->excu("$query"); 
if(mysql_ num rows(S$rst)>=1){ 
while($info=mysql_fetch_array($rst){ 
o> 
<option value="<?php echo $info["id"]:?>"><?php echo $info["type_name"] ;?></option> 
<2php 
} 
} 
?> 
</select></td> 
</t> 
<tr> 
<td height="30" align="right" valign="middle" bgcolor="#FFFFFF"> 日 志 标 题 : </td> 
<td align="left" valign="middle" bgcolor="#FFFFFF"><input name="title" type="text" size="40" 
maxlength="60"/></td> 
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<td align="right" valign="middle" bgcolor="#FFFFFF"> 日 志 内 容 : </td> 
<td align="left" valign="middle" bgcolor="#FFFFFF"> 
<textarea name="content" cols="45" rows="15"></textarea></td> 
</tr> 
<tr> 
<td height="30" colspan="2" align="center" valign="middle" bgcolor ="#FFFFFF"><input 
type="submit" name="submit" value=" 提 交 " />&nbsp;&nbsp;&nbsp; &nbsp;<input type="reset" 
name="Submit2" value=" 重 置 " /></td> 
</tr> 
</table> 
</form> 
//=——————————————— manage/blog_manage.php 
<2php 
include "session.php"; 
$del id=$_ GET["del id"]; 
$type_id=$_GET["type id"]; 
/删除 日 志 操作 
if($del id!=""){ 
$query="delete from blog_info where id='$del id' and user id='$_ SESSION [user id]"; 
S$folie->excu($query); 
echo" 日 志 删 除 成 功 !"; 


} 

?> 

<h4> 日 志 管 理 <br>-<?php echo $crazy->type_idto_name($type_id):?></h4> 

<2php 

$query="select * from blog_info where type_id='$type_id' and user id =$_ SESSION[user id]' order by 


id desc"; 
Srst=$folie->excu($query); 
if(mysql_ num rows($rst)>=1){ 
$add="user.php?target=blog_manage&type id=".$type_id."&"; 
S$pagesize=2; 
S$crazy->pagination($query.$page_id,$add,$pagesize):; 
S$rst=$folie->excu($query); 
?> 
<table width="450" border="1" cellpadding="0" cellspacing="0" bordercolor ="#CCCCCC" 
style="border-collapse:collapse"> 
<tr> 
<td width="8%" height="25" align="center"> 序 号 </td> 
<td width="62%" align="center"> 标 题 </td> 
<td colspan="2" align"center"> 操 作 </td> 
</tr> 
<2php 
$i=1; 
while($info=mysql_fetch_array($rst){ 
> 
<tr> 
<td width="8%" height="25" align="center"><?php echo $1:?></td> 
<td width="62%"><?php echo $info["title"]:?></td> 
<td width="15%" align="center"><a href="user.php?target=blog_edit&type id=<?php echo 
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$type_ id:?>&blog id=<?php echo $info["id"];?>"> 编 辑 </a></td> 


<td width="15%" align="center"><a href="user.php?target=blog_ manage&t ype_id=<?php echo 
$type _id;?>&del id=<?php echo $info["id"]:?>"> 删 除 </a></td> 
</tr> 
<?php 
Si++; 
} 
?> 
</table> 
<2php 
j}else { 
echo "该 分 类 下 和 暂 无 日 志 。"; 
» 


?> 


(4) 管理 用 户 文件 。 
回 login.php 


<2php 
include "inc/mysqlinc.php": 
include "inc/myfunction.php"; 
include "inc/head.php"; 
S$folie=new mysql; 
$crazy=new myfunction; 
$folie->link("™"); 
// 接 收 变量 
$submit=$_POST["submit"]; 
1/ 用户 登录 验证 
if$submit 一 "提交 "){ 
$user_ name=$ POST["user name"]; 
$query="select * from manage_info where manage_user='$user_name"™; 
S$rst=$folie->excu($query); 
if(mysql_num rows($rst)>=1){ 
S$info=mysql_fetch_array($rst); 
$user pw=$_POST["user pw"]; 
if($user pw 一 $info["manage pw"]){ 
$_SESSION["super_name"]=$user_name'; 
$_SESSION["super tag"] 
$crazy->js_alert(" 登 录 成 功 !"," 
}else { 
$crazy->js_alert(" 用 户 名 或 密码 错误 !","login.php"); 


‘super/index.php"); 


} 
}else { 


$crazy->js_alert(" 用 户 名 或 密码 错误 !","login.php"); 
} 
和 
?> 
<p>&nbsp:</p> 
<!-- 用 户 登 录 表 单 、 表 格 ， 纯 HTML 代码 ， 略 --> 
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<?php 
include "inc/footphp": 
?> 


加 super/index.php 


<?php 

include "session.php"; 

include "../inc/mysql.inc.php"; 

include "../inc/myfunction.php"; 

include "../inc/head2 .php"; 

Sfolie=new mysql; 

$crazy=new myfunction; 

Sfolie->link(""); 

Stag=$_GET["tag"]; 

$user id=$_ GET["user id"]; 

if($tag—0){ 
$query="update user_info set tag='$tag’ where id='$user_id"; 
S$rst=$folie->excu($query); 

}else if($tag==1){ 
$query="update user_info set tag='$tag’ where id='$user_id"; 
S$rst=$folie->excu($query); 

} 


/删除 用 户 

$del id=$_ GET["del id"]; 

if($del id!=""){ 
$query="delete from user info where id="$del id"™"; 
$namel = "../config/config".$del id.".ine"; 
$name2 /config/sta_say".$del id.".txt"; 
$name3 ="../config/link".$del id.".txt"; 
@unlink($namel); 
@unlink($name?2); 
@unlink($name3); 
S$rst=$folie->excu($query); 


} 
和 
<table width="752" border="0" cellpadding="0" cellspacing="0" style= "border-collapse:collapse"> 
<tr> 
<td width="1" height="199" bgcolor="#CCCCCC"></td> 
<td colspan="2" align="center" valign="top"><table width="90%" border ="0" cellpadding="0" 
cellspacing="0" bgcolor="#FFFFFF"> 
<tr> 
<td align="center" valign="top"> 
<!-- 显 示 所 有 用 户 --><br> 
<2php 
$query="select * from User info order by id desc": 
S$rst=$folie->excu($query); 
if(mysql num rows($rst)>=1){ 
人 T 7 $add="index.php?"; 
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S$pagesize=10; 
$crazy->pagination($query,$page_id,$add,$pagesize); 
Srst=$folie->excu($query): 
?> 
<table width="98%" border="1" cellpadding="0" cellspacing="0" bordercolor="#CCCCCC" 
style="border-collapse:collapse"> 
<tr> 


<td width="8%" height="25" align="center"> 序 号 </td> 
<td width="14%" align="center"> 昵 称 </td> 
<td width="30%" align="center"> 注 册 时 间 </td> 
<td width="30%" align="center"> 最 后 登录 时 间 </td> 
<td width="9%" align="center"> 状 态 </td> 
<td width="9%" align="center"> 操 作 </td> 
</tr> 
<?php 
$i=1; 
while($info=mysql fetch array($rst)){ 
?> 
<tr align="center" valign="middle"> 
<td height="25"><?php echo $1:7?></td> 
<td><?php echo $info["user name"];?></td> 
<td><?php echo $info["r_time"]:?></td> 
<td><?php echo $info["last_time"];?></td> 
<td><?php 
if($info["tag"]—D){ 
?><a href="index.php?user_id=<?php echo $info["id"];?>&tag=0"> 显 示 </a><?php 
}else {2?><a href="index.php?user_id=<?php echo $info["id"]:?> &tag=1"> 隐 藏 </a><?php 
} 
?></td> 
<td><a href="index.php?del_id=<?php echo $info["id"];?>"> 删 除 </a></td> 
</tr> 
<2php 
Si++; 
} 
?> 
</table> 
<2php 
}else { 
echo " 暂 无 用 户 注 册 。"; 
> 
</td> 
</tr> 
</table></td> 
<td width="1" bgcolor="#CCCCCC"></td> 
</tr> 
<tr> 
<td height="1" colspan="3" bgcolor="#CCCCCC"></td> 
</tr> 
</table> 
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<?php 
include "../inc/foot.php"; 
?> 


回 super/session.php 


<?php 

这 $_ SESSION["super name"] 一 "or$ SESSION["super tag"] 一 ""){ 
header("location:../index.php"); 

b: 


?> 


(5) 浏览 用 户 文件 。 
回 indexphp 


<2php 
include "inc/mysql.inc.php"; 
include "inc/myfunction.php"; 
S$folie=new mysql; 
S$crazy=new myfunction; 
S$folie->link("™"); 
include "inc/head.php"; 
/搜索 用 户 提交 的 用 户 名 是 否 存在 ， 存 在 直接 跳 转 到 其 博客 主页 ， 不 存在 弹出 提示 信息 
$search tag =$_GET["search tag"]; 
if($search tag =—="1"){ 
$user name =$ POST["user name"]; 
$query = "select * from user_info where user_name = '$user name"; 
S$rst = $folie->excu($query); 
if(mysql_num rows($rst)>=1){ 
S$info2 = mysql_ fetch_array($rst): 
/echo “<script>location.href='http://www.baidu.com';</script>"; 
echo "<script>window.open('myblog.php?user_id=$info2[id]"):</script>"; 
}else { 
echo "<script>alert( 无 此 用 户 ):</script>"; 
} 
上 
Ts 
<table width="752" border="0" align="center" cellpadding="0" cellspacing="0" 
style="border-collapse:collapse"> 
<tr> 
<td width="1" height="199" bgcolor="#CCCCCC"></td> 
<td colspan="2" align="center" valign="top"><table width="100%" border="0" cellspacing="0" 
cellpadding="0"> 
<tr> 
<td height="25" align="center"><table width="98%" border="0" cellspacing="0" 
cellpaddine="0"> 
<form action="index.php?search_tag=1" method="post"> 


<tr> 
<td width="10%" align="right" valign="middle"> 用 户 名 : </td> 
\y/ <td width="90%"><input type="text" name="user name" /> 
~ 
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&nbsp; <input type="submit" name="Submit" value= "搜索 " /></td> 


</tr> 
</form> 
</table></td> 
</tr> 
<tr> 
<td align="center"> 
<?php 
$query = "select * from user_info where tag = '1' order by r_time desc"; 
S$rst = $folie->excu($query); 
if(mysql_ num rows($rsb >= 1){ 
?> 
<table width="94%" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td height="26" align="left" valign="middle"><?php 
S$crazy->pagination($query,$page_id,"?",10); 
S$rst = $folie->excu($query); 
?></td> 
</tr> 
</table> 
<2php 
while($info = mysql_fetch_array($rsb){ 
?> 


<table width="94%" border="1" cellpadding="0" cellspacing="0" bordercolor="#666666" 
style="border-collapse:collapse:"> 
<tr> 
<td width="180" height="170" align="center"><?php 
$query_ph = "select * from pic_info where user id = "$info [idj andtarget='2 and tag ="1"; 
S$rst_ph = $folie->excu($query_ph); 
if(mysql_ num rows($rst_ph) 一 1){ 
S$info ph = mysql_fetch_array($rst_ph); 
echo "<a href=myblog.php?user id=".$info["id"]." target =' blank><img 
src=pic_sys/".$info_ph["addr"]." width="150' height='150' bor der="0'></a>"; 
}else { 
echo "无 "; 
上 
?></td> 
<td width="519" align="center" valign="top"><table width="98%" border="0" 
cellspacing="0" cellpadding="0"> 
<tr> 
<td width="15%" height="30" align="right" valign="middle"> 博 主 昵称 :</td> 
<td width="85%" align="left" valign="middle"><a href= myblog.php? 
user_name=<?php echo $info["user name"];?> target="_blank'’><?php echo 
$info["user name"]:?></a></td> 
<t> 
<tr> 
<td height="30" align="right" valign="top"> 博 主 的 话 : </td> 
<td valign="top"><?php 


// 输 出 博 主 的 话 
$name="sta_say".$info["id"]; 
if (I@$fp=file("config/$name.txt")){ 
echo "无 ! <br>"; 
Jelse{ 
for ($i=0;$i<count($fp):$i++){ 
$sta_say.=$fp[$i]; 
3 
echo $sta_say; 
: 
?></td> 
</tr> 
</table></td> 
</tr> 
</table> 
<br /> 
<?php 
》 
jelse { 
echo "无 注册 用 户 。"; 
} 
?></td> 
</tr> 
</table></td> 
<td width="1" bgcolor="#CCCCCC"></td> 
</tr> 
<tr> 
<td height="1" colspan="3" bgcolor="#CCCCCC"></td> 
</tr> 
</table> 
<2php 
include "inc/foot.php"; 
?> 


回 ”myblog.php 


<?php 

include "inc/mysqlLinc.php"; 

include "inc/myfunction.php"; 

S$folie=new mysql; 

S$crazy=new myfunction; 

S$folie->link("™"); 

$user id=$_ GET["user id"]:; 

$query="select * from user_info where id="'$user id": 
Srst=$folie->excu($query); 

if (mysql num rows($rst)=——=0){ 
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echo "一 您 要 访问 的 用 户 的 博客 已 经 被 系统 管理 员 删除 或 根本 就 不 存在 ! 一 "; 


exit: 


} 


Z S$info=mysql fetch_array($rst); 
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if ($info["tag"]==0){ 


echo" 一 该 用 户 的 博客 已 经 被 系统 管理 员 屏 项 (一 "; 

exit; 

和 

include "inc/head1.php": 

?> 

<table width="752" border="0" cellpadding="0" cellspacing="0" style ="border-collapse:collapse"> 
<tr> 


<td width="1" height="199" bgcolor="#CCCCCC"></td> 
<td width="488" align="center" valign="top"><table width="490" border ="0" cellpadding="0" 
cellspacing="0" bgcolor="#FFFFFF"> 
<tr> 
<td height="660" align="center" valign="top"><br /> 
<!-- 显 示 日 志 内 容 --><div align="left"><?php 
$query="select * from blog _ info where user_ id=-'$user id' order by add time desc"; 
S$rst=$folie->excu($query); 
if(mysql num rows($rst)>=1){ 
$add="myblog.php?user id=$user id&"; 
S$pagesize=6; 
Scrazy->pagination($query,$page_id,$add,$pagesize); 
S$rst=$folie->excu($query); 
while($info_blog=mysql fetch array($rst)){ 


?></div> 
<table width="98%" border="0" cellspacing="0" cellpadding="5"> 
<tr> 
<td height="30" class="titlel"><?php echo $info_blog["title"];? ></td> 
</t> 
<tr> 
<td class="cont"><?php echo $info_blog["cont"]:?></td> 
</tr> 
<tr> 
<td height="30"><table width="100%" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td width="20%" align="center" class="title2"><a href="blog comm.php?user_id= 
<?php echo $user id:?>&blog id=<?php echo $info_ blog["id"]:?> "> 发 表 评 论 
</a></td> 
<td width="30%" class="title2"> 分 类 : <?php echo $crazy->blog type_idto_name 
($info_blog["type id"]):?></td> 
<td width="50%" class="title2"> 时 间 : <?php echo $info_blog ["add time"];?>&nbsp; 
&nbsp: <a href="blog_comm.php?user id=<?php echo $user id; ?>&blog id=<?php 
echo $info_blog["id"];?>"> 查 看 全 文 </a></td> 
</tr> 
</table></td> 
</t> 
</table> 
<hr> 
<2php 
} 
} 
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</t> 
</table></td> 
<td width="1" bgcolor="#CCCCCC"></td> 
<td width="257" align="center" valign="top"><?php include "menu.php";?> </td> 
<td width="1" bgcolor="#CCCCCC"></td> 
</tr> 
<tr> 
<td height="1" colspan="3" bgcolor="#CCCCCC"></td> 
<td width="258" colspan="2" bgcolor="#CCCCCC"></td> 
</tr> 
</table> 
<?php 
include “inc/myfoot.php"; 
3 


回 type blog.php 


<2php 
include "inc/mysql.inc.php"; 
include "inc/myfunction.php"; 
/linclude "inc/head.php"; 
S$folie=new mysql; 
$crazy=new myfunction; 
Sfolie->link(""); 
$user id=$_GET["user id"]; 
$type_id=$_GET["type_id"]; 
include "inc/head1 .php"; 
> 
<table width="752" border="0" cellpadding="0" cellspacing="0" style="bor der-collapse:collapse"> 
<tr> 
<td width="1" height="199" bgcolor="#CCCCCC"></td> 
<td width="488" align="center" valign="top"><table width="490" border ="0" cellpadding="0" 
cellspacing="0" bgcolor="#FFFFFF"> 
<tr> 
<td height="660" align="center" valign="top"><br/> 
<!-- 显 示 日 志 内 容 --><div align="left"> 
<2php 
$query="select * from blog info where type id- type id and user_id='$user id order by add time desc"; 
S$rst=$folie->excu($query):; 
这 mysql_ num rows($rst)>=1){ 
$add="type_blog.php?user id=$user id&type id=$type_id&"; 
$pagesize=3; 
$crazy->pagination($query,$page_id,$add,$pagesize): 
S$rst=$folie->excu($query); 
while($info_blog=mysql fetch array($rst)){ 
?></div> 
<table width="98%" border="0" cellspacing="0" cellpadding="S"> 
<tr> 
<td height="30" class="titlel"><?php echo $info_blog["title"]:?> </td> 
</t> 
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<tr> 
<td class="cont"><?php echo $info_blog["cont"]:?></td> 
</t> 


<tr> 
<td height="30"><table width="100%" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td width="20%" align="center" class="title2"><a hre 全 "blog_ comm.php?user id= 
<?php echo $user id;?>&blog id=<?php echo $info blog["id"]:?>"> 发 表 评论 
</a></td> 
<td width="30%" class="title2"> 分 类 : <?php echo $crazy->blog_type_idto_name 
($info blog["type id"]):?></td> 
<td width="50%" class="title2"> 时 间 : <?php echo $info_blog ["add time"]:?></td> 
</tr> 
</table></td> 
</tr> 
</table> 
<hr 这 
<2php 
} 
jelse{ 
echo "<br><br> 该 分 类 下 和 暂 无 日 志 。"; 
} 
?></td> 
</tr> 
</table></td> 
<td width="1" bgcolor="#CCCCCC"></td> 
<td width="257" align="center" valign="top"><?php include "menu.php";?> </td> 
<td width="1" bgcolor="#CCCCCC"></td> 
</tr> 
<tr> 
<td height="1" colspan="3" bgcolor="#CCCCCC"></td> 
<td width="258" colspan="2" bgcolor="#CCCCCC"></td> 
</tr> 
</table> 
<?php 
include "inc/foot.php"; 
?> 


回 day blog php 


<?php 

include "inc/mysqlinc.php"; 
include "inc/myfunction.php"; 
$folie=new mysql; 
S$crazy=new myfunction; 
S$folie->link("™"); 

// 接 收 变量 

Suser id=$_ GET["user id"]; 
include "inc/head1 .php"; 
$type id-$_ GET["type id"]; 
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$day=$_ GETI["day"]; 
?> 
<table width="752" border="0" cellpadding="0" cellspacing="0" style= "border-collapse:collapse"> 
<tr> 
<td width="1" height="199" bgcolor="#CCCCCC"></td> 
<td width="488" align="center" valign="top"><table width="490" border="0" cellpadding="0" 
cellspacing="0" bgcolor="#FFFFFF"> 
<tr> 
<td height="660" align="center" valign= "top"><br /> 
<!-- 显 示 日 志 内 容 --><div align="left"> 
<?php 
$query="select * from blog _ info where add_time like '$day9%o' and user id='$user id"; 
if($type id!=""){ 
$query.=" and type_id='$type_id"; 
上 
$query.=" order by add time desc"; 
S$rst=$folie->excu($query); 
这 mysql num rows($rst)>=1){ 
$add="day_blog.php?user id=$user id&type id=$type_ id&day=$day&"; 
S$pagesize=3; 
Scrazy->pagination($query, $page_id,$add,$pagesize); 
Srst=$folie->excu($query); 
while($info_blog=mysql_ fetch array($rst){ 
?></div> 
<table width="98%" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td>&nbsp:</td> 
</tr> 
</table> 
<table width="98%" border="0" cellspacing="0" cellpadding="5"> 
<tr> 
<td height="30" class="titlel"><?php echo $info blog["title"]; ?></td> 
</tr> 
<tr> 
<td class="cont"><?php echo $info_blog["cont"]:?></td> 
</tr> 
<tr> 
<td height="30"><table width="100%" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td width="20%" align="center" class="title2"><a href="blog_ comm.php?user 1d= 
<?php echo $user id;?>&blog id=<?php echo $info_blog["id"]:? >"> 发 表 评论 
</a></td> 
<td width="30%" class="title2"> 分 类 : <?php echo $crazy->blog_type_idto_name 
($info_blog["type 1d"]):?></td> 
<td width="50%" class="title2"> 时 间 : <?php echo $info_blog ["add time"]:?></td> 
</tr> 
</table></td> 
</t> 
</table> 
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}else { 
echo "<br><br> 该 分 类 下 暂 无 日 志 。"; 


} 


?></td> 
</tr> 
</table></td> 
<td width="1" bgcolor="#CCCCCC"></td> 
<td width="257" align="center" valign="top"><?php include “menu.php";?> </td> 
<td width="1" bgcolor="#CCCCCC"></td> 
</tr> 
<tr> 
<td height="1" colspan="3" bgcolor="#CCCCCC"></td> 
<td width="258" colspan="2" bgcolor="#CCCCCC"></td> 
</tr> 
</table> 
<2php 
include "inc/foot.php"; 
?> 


5. 运行 测试 
最 后 要 对 本 系统 进行 运行 测试 ， 读 者 可 以 通过 安装 测试 、 注 册 用 户 测试 、 管 理 用 户 测 
试 、 浏 览 用 户 测试 等 自己 动手 进行 测试 。 


‘Ooo 
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